リンクリスト操作
1. InitList(L): リンクリストを初期化します
2. DestroyList(L): 接続を削除します
3. ClearList(L): リンクされたリストをクリアします
4. ListEmpty(L): 空かどうかを判断します
5. ListLength(L): リンクされたリストの長さ
6. getElem(L,i): 要素を取り出します
7. LocateElem(L,e): e がリンクされたリストにあるかどうかを判断します
8. PriorElem(L,i): プリカーサー
9. NextElem(L,i): 後継者
10. ListInsert(L,i,e): 要素を挿入します
11. ListDelete(L,i,): 要素を削除します
逐次リンクリスト操作
classArrayList{
プライベート$リスト;
プライベート$サイズ
//コンストラクター
パブリック関数__construct(){
$this->list=array();
$this->size=0;
}
パブリック関数initList(){
$this->list=array();
$this->size=0;
}
//リンクされたリストを削除します
パブリック関数 destroyList(){
if(isset($this->list)){
unset($this->list);
$this->size=0;
}
}
//リンクされたリストをクリアします
パブリック関数clearList(){
if(isset($this->list)){
unset($this->list);
}$this->list=array();
$this->size=0;
}
//リンクされたリストが空かどうかを判断します
パブリック関数 emptyList(){
if(isset($this->list)){
if($this->size=0)
TRUE を返します;
その他
FALSE を返す;
}
}
//リンクされたリストの長さ
パブリック関数 lengthList(){
if(isset($this->list)){
return $this->size;
}
}
//要素を取得します
パブリック関数 getElem($i){
if($i<1||$i>$this->size){
echo "オーバーフロー
終了();
}
if(isset($this->list)&&is_array($this->list)){
return $this->list[$i-1];
} }
}
//リンクリストにあるかどうか
パブリック関数locateElem($e){
if(isset($this->list)&&is_array($this->list)){
for($i=0;$i<$this->size;$i++){
if($this->list[$i]==$e){
$i+1 を返します。
}
}
0 を返す;
}
}
//先駆者
パブリック関数 PriorElem($i){
if($i<1||$i>$this->size){
echo "オーバーフロー";
終了();
}
if($i==1){
あり あり あり 前輪なし、
exit();
}
if(isset($this->list)&&is_array($this->list)){
return $this->list[$i-2];
}
}
//後继
パブリック関数 nextElem($i){
if($i<1||$i>$this->size){
echo "溢れ出";
exit();
}
if($i==$this->size){
echo "没有后继";
exit();
}
if(isset($this->list)&&is_array($this->list)){
return $this->list[$i];
}
}
//插入元素
public function insertList($i,$e){
if($i<1||$i>$this->size+1){
echo "插入元素位置有误";
exit();
}
if(isset($this->list)&&is_array($this->list)){
if($this->size==0){
$this->list[$this->size]=$e;
$this->size++;
}その他{
$this->size++;
for($j=$this->size-1;$j>=$i;$j--){
$this->list[$j]=$this->list[$j-1];
}
$this->list[$i-1]=$e;
}
}
}
//删除元素
パブリック関数 deleteLlist($i){
if($i<1||$i>$this->size){
echo "删除元素位置有误";
exit();
}
if(isset($this->list)&&is_array($this->list)){
if($i==$this->size){
unset($this->list[$this->size-1]);
}その他{
for($j=$i;$j<$this->size;$j++){
$this->list[$j-1]=$this->list[$j];
}
unset($this->list[$this->size-1]);
}
$this->size--;
}
}
//遍历
パブリック関数 printList(){
if(isset($this->list)&&is_array($this->list)){
foreach ($this->リストを $value として){
echo $value." ";
}
echo "
";
}
}
}
?>
//链式線性表
クラスリンクリスト{
プライベート $head;
プライベート $size;
プライベート $リスト;
public function__construct(){
$this->head="";
$this->size=0;
$this->list=array();
}
public functioninitList(){
$this->head="";
$this->size=0;
$this->list=array();
}
//删除链表
public functiondestoryList(){
if(isset($this->list)&&isset($this->head)){
unset($this->list);
unset($this->head);
}
}
//清空链表
public functionclearList(){
if(isset($this->list)){
unset($this->list);
}
$this->list=array();
$this->size=0;
$this->head="";
}
// 链表が空かどうか判断する
public functionemptyList(){
if(isset($this->list)){
if($this->size==0)
returnTRUE;
その他
returnFALSE;
}
}
//链表長度
public functionlengthList(){
if(isset($this->list)){
return$this->size;
}
}
//取元素
パブリック関数 getElem($i){
if($i$this->size){
echo "溢れ出
;
exit();
}
if(isset($this->list)&&is_array($this->list)){
$j=1;
//头指针
$tmp=$this->head;
while($i>$j){
if($this->list[$tmp]['next']!=null){
$tmp=$this->list[$tmp]['next'];
$j++;
}
}
return $this->list[$tmp]['data'];
}
}
//链表中にあるかどうか
public functionlocateElem($e){
if(isset($this->list)&&is_array($this->list)){
$tmp=$this->head;
while($this->list[$tmp]['data']!=$e){
if($this->list[$tmp]['next']!=null){
$tmp=$this->list[$tmp]['next'];
}その他{
returnFALSE;
}
}
TRUE を返します;
}
}
//前驱
public functionpriorElem($i){
if($i=$this->size){
echo "溢れ出";
exit();
}
if($i==1){
echo "没有前驱";
exit();
}
$tmp=$this->head;
$j=1;
while($i>$j+1){
if($this->list[$tmp]['next']!=null){
$j++;
$tmp=$this->list[$tmp]['next'];
}
}
return$this->list[$tmp]['data'];
}
//後继
public functionnextElem($i){
if($i$this->size){
echo "溢れ出";
exit();
}
if($i==$this->size){
echo "没有后继";
exit();
}
$j=1;
$tmp=$this->head;
while($i>=$j){
if($this->list[$tmp]['next']!=null){
$j++;
$tmp=$this->list[$tmp]['next'];
}
}
return$this->list[$tmp]['data'];
}
//插入元素:後插法
public functioninsertList($i,$e){
if(isset($this->list)&&is_array($this->list)){
//空表
if($this->size==0){
$this->head=$this->uuid();
$this->list[$this->head]['data']=$e;
$this->list[$this->head]['next']=NULL;
$this->size++;
}その他{
if($i$this->size){
echo"插入元素位置有误";
exit();
}
$j=1;
$tmp=$this->head;
while($i>$j){
if($this->list[$tmp]['next']!=null){
$j++;
$tmp=$this->list[$tmp]['next'];
}
}
$find=$tmp;
$id=$this->uuid();
if($this->list[$find]['next']==null){
//尾部
$this->list[$find]['next']=$id;
$this->list[$id]['data']=$e;
$this->list[$id]['next']=null;
$this->size++;
}その他{
//中间
$this->list[$id]['next']=$this->list[$find]['next'];
$this->list[$find]['next']=$id;
$this->list[$id]['data']=$e;
$this->size++;
}
}
}
}
//删除元素
public functiondeleteLlist($i){
if($i$this->size){
echo "删除元素位置有误";
exit();
}
if(isset($this->list)&&is_array($this->list)){
if($i==1){
//删除头元素
$this->head=$this->list[$this->head]['next'];
}その他{
$tmp=$this->head;
$j=1;
while($i>$j+1){
if($this->list[$tmp]['next']!=null){
$j++;
$tmp=$this->list[$tmp]['next'];
}
}
//找到删除元素的前驱
$find=$tmp;
//删除的元素
if($this->list[$find]['next']!=null){
//不是最後一元素
$delete=$this->list[$find]['next'];
$this->list[$find]['next']=$this->list[$delete]['next'];
}その他{
$this->list[$tmp]['next']=null;
}
}
}
}
public functiontraverstList(){
$tmp=$this->head;
while($this->list[$tmp]['next']!=NULL){
$this->printList($this->list[$tmp]['data'],TRUE);
$tmp=$this->list[$tmp]['next'];
}
$this->printList($this->list[$tmp]['data'],FALSE);
}
public functionprintList($str,$flag){
if($flag){
echo$str."->";
}else {
echo$str."
";
}
}
//uuid 唯一のコード
public function uuid($prefix = '') {
$chars =md5(uniqid(mt_rand(), true));
$uuid = substr($chars,0,8) 。 「-」;
$uuid .=substr($chars,8,4) 。 「-」;
$uuid .=substr($chars,12,4) 。 「-」;
$uuid .=substr($chars,16,4) 。 「-」;
$uuid .= substr($chars,20,12);
$prefix を返します。 $uuid;
}
}
?>