php實現(xiàn)兩表合并成新表并且有序排列的方法
更新時間:2014年12月05日 12:02:30 投稿:shichen2014
這篇文章主要介紹了php實現(xiàn)兩表合并成新表并且有序排列的方法,涉及針對數(shù)組的遍歷與排序操作技巧,具有一定的實用價值,需要的朋友可以參考下
本文實例講述了php實現(xiàn)兩表合并成新表并且有序排列的方法。分享給大家供大家參考。
具體實現(xiàn)方法如下:
復(fù)制代碼 代碼如下:
<?php
/**
la (3,5,8,11)
lb(2,6,8,9,11,15)
合并為lc,有序排列。
用php實現(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個元素,返回
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實現(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個元素,返回
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);
?>
希望本文所述對大家的PHP程序設(shè)計有所幫助。
您可能感興趣的文章:
- 逆序二維數(shù)組插入一元素的php代碼
- php一個解析字符串排列數(shù)組的方法
- php求數(shù)組全排列,元素所有組合的方法
- PHP+MySQL統(tǒng)計該庫中每個表的記錄數(shù)并按遞減順序排列的方法
- php通過排列組合實現(xiàn)1到9數(shù)字相加都等于20的方法
- PHP使用array_merge重新排列數(shù)組下標(biāo)的方法
- 使用php計算排列組合的方法
- php全排列遞歸算法代碼
- php 遍歷數(shù)據(jù)表數(shù)據(jù)并列表橫向排列的代碼
- 深入理解PHP幾個算法:PHP冒泡、PHP二分法、PHP求素數(shù)、PHP乘法表
- php遞歸法讀取目錄及文件的方法
- PHP字符串逆序排列實現(xiàn)方法小結(jié)【strrev函數(shù),二分法,循環(huán)法,遞歸法】
相關(guān)文章
PHP寫入WRITE編碼為UTF8的文件的實現(xiàn)代碼
可以把uft-8格式的文件,寫到文本中的實現(xiàn)代碼2008-07-07php實現(xiàn)pdo數(shù)據(jù)庫操作類過程詳解
這篇文章主要介紹了php實現(xiàn)pdo數(shù)據(jù)庫操作類過程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-12-12PHP WebSocket的技術(shù)解析與使用指南詳解
在這篇文章中我們將深入討論從建立連接、綁定到監(jiān)聽等各方面的操作,并提供易于理解和實踐的指導(dǎo),希望可以幫助大家掌握在PHP中使用WebSocket的關(guān)鍵概念和技術(shù)2024-02-02php實現(xiàn)與erlang的二進(jìn)制通訊實例解析
這篇文章主要介紹了php實現(xiàn)與erlang的二進(jìn)制通訊實例解析,需要的朋友可以參考下2014-07-07