php實(shí)現(xiàn)兩表合并成新表并且有序排列的方法
更新時(shí)間:2014年12月05日 12:02:30 投稿:shichen2014
這篇文章主要介紹了php實(shí)現(xiàn)兩表合并成新表并且有序排列的方法,涉及針對(duì)數(shù)組的遍歷與排序操作技巧,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下
本文實(shí)例講述了php實(shí)現(xiàn)兩表合并成新表并且有序排列的方法。分享給大家供大家參考。
具體實(shí)現(xiàn)方法如下:
復(fù)制代碼 代碼如下:
<?php
/**
la (3,5,8,11)
lb(2,6,8,9,11,15)
合并為lc,有序排列。
用php實(shí)現(xiàn),不能用sort之類的函數(shù)?。。?!
**/
class union {
var $lista = array();
var $listb = array();
var $listc = array();
function getlenght($arr) { //獲得表長度
return count($arr);
}
function getelement($arr, $n) { //獲取表中第n個(gè)元素,返回
return $e = $arr[$n] ? $arr[$n] : '';
}
function listinsert($arr, $e) { //表末尾插入元素
$arr[] = $e;
return $arr;
}
}
$phpig = new union();
$lista = $phpig->lista = array(3, 5, 8, 11);
$listb = $phpig->listb = array(2, 6, 8, 9, 11, 15);
$listc = $phpig->listc;
$lena = $phpig->getlenght($lista); //取得表大小
$lenb = $phpig->getlenght($listb);
$i = $j = 0;
while($i < $lena && $j < $lenb) {
$ea = $phpig->getelement($lista, $i);
$eb = $phpig->getelement($listb, $j);
if($ea <= $eb) {
$listc = $phpig->listinsert($listc, $ea);
++$i;
} else {
$listc = $phpig->listinsert($listc, $eb);
++$j;
}
}
while($i < $lena) {
$ea = $phpig->getelement($lista, $i);
$listc = $phpig->listinsert($listc, $ea);
++$i;
}
while($j < $lenb) {
$eb = $phpig->getelement($listb, $j);
$listc = $phpig->listinsert($listc, $eb);
++$j;
}
print_r($listc);
?>
/**
la (3,5,8,11)
lb(2,6,8,9,11,15)
合并為lc,有序排列。
用php實(shí)現(xiàn),不能用sort之類的函數(shù)?。。?!
**/
class union {
var $lista = array();
var $listb = array();
var $listc = array();
function getlenght($arr) { //獲得表長度
return count($arr);
}
function getelement($arr, $n) { //獲取表中第n個(gè)元素,返回
return $e = $arr[$n] ? $arr[$n] : '';
}
function listinsert($arr, $e) { //表末尾插入元素
$arr[] = $e;
return $arr;
}
}
$phpig = new union();
$lista = $phpig->lista = array(3, 5, 8, 11);
$listb = $phpig->listb = array(2, 6, 8, 9, 11, 15);
$listc = $phpig->listc;
$lena = $phpig->getlenght($lista); //取得表大小
$lenb = $phpig->getlenght($listb);
$i = $j = 0;
while($i < $lena && $j < $lenb) {
$ea = $phpig->getelement($lista, $i);
$eb = $phpig->getelement($listb, $j);
if($ea <= $eb) {
$listc = $phpig->listinsert($listc, $ea);
++$i;
} else {
$listc = $phpig->listinsert($listc, $eb);
++$j;
}
}
while($i < $lena) {
$ea = $phpig->getelement($lista, $i);
$listc = $phpig->listinsert($listc, $ea);
++$i;
}
while($j < $lenb) {
$eb = $phpig->getelement($listb, $j);
$listc = $phpig->listinsert($listc, $eb);
++$j;
}
print_r($listc);
?>
希望本文所述對(duì)大家的PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:
- 逆序二維數(shù)組插入一元素的php代碼
- php一個(gè)解析字符串排列數(shù)組的方法
- php求數(shù)組全排列,元素所有組合的方法
- PHP+MySQL統(tǒng)計(jì)該庫中每個(gè)表的記錄數(shù)并按遞減順序排列的方法
- php通過排列組合實(shí)現(xiàn)1到9數(shù)字相加都等于20的方法
- PHP使用array_merge重新排列數(shù)組下標(biāo)的方法
- 使用php計(jì)算排列組合的方法
- php全排列遞歸算法代碼
- php 遍歷數(shù)據(jù)表數(shù)據(jù)并列表橫向排列的代碼
- 深入理解PHP幾個(gè)算法:PHP冒泡、PHP二分法、PHP求素?cái)?shù)、PHP乘法表
- php遞歸法讀取目錄及文件的方法
- PHP字符串逆序排列實(shí)現(xiàn)方法小結(jié)【strrev函數(shù),二分法,循環(huán)法,遞歸法】
相關(guān)文章
PHP寫入WRITE編碼為UTF8的文件的實(shí)現(xiàn)代碼
可以把uft-8格式的文件,寫到文本中的實(shí)現(xiàn)代碼2008-07-07php實(shí)現(xiàn)pdo數(shù)據(jù)庫操作類過程詳解
這篇文章主要介紹了php實(shí)現(xiàn)pdo數(shù)據(jù)庫操作類過程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-12-12shopex中集成的站長統(tǒng)計(jì)功能的代碼簡單分析
shopex中集成了一鍵開啟站長統(tǒng)計(jì)功能,而無需去CNZZ注冊(cè),在phpcms,phpwind等中也都有類似的功能,下面是對(duì)這個(gè)功能的簡單分析,以后也可以偷偷用在自己的網(wǎng)站中,呵呵。2011-08-08PHP WebSocket的技術(shù)解析與使用指南詳解
在這篇文章中我們將深入討論從建立連接、綁定到監(jiān)聽等各方面的操作,并提供易于理解和實(shí)踐的指導(dǎo),希望可以幫助大家掌握在PHP中使用WebSocket的關(guān)鍵概念和技術(shù)2024-02-02php實(shí)現(xiàn)與erlang的二進(jìn)制通訊實(shí)例解析
這篇文章主要介紹了php實(shí)現(xiàn)與erlang的二進(jìn)制通訊實(shí)例解析,需要的朋友可以參考下2014-07-07