久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费
標題:
利用二級指針實現單鏈表相鄰結點交換
[打印本頁]
作者:
1242617185
時間:
2016-6-4 01:18
標題:
利用二級指針實現單鏈表相鄰結點交換
利用冒泡法對單鏈表進行排序需要交換兩個相鄰結點,利用二級指針可以很方便地解決結點交換的問題
下面我們生成一個鏈表,每個結點儲存一個隨機值,然后對該鏈表進行排序。其中排序算法的實現過程也同時實現了相鄰兩個結點的交換。
#include < stdio.h >
#include < stdlib.h >
#include < time.h >
#define FALSE 0
#define TRUE 1
typedef struct NODE{ //鏈表節點的結構體聲明
struct NODE *link;
int value;
}Node;
int sort(register Node **head,int length); //排序函數的原型聲明
int main(void)
{
int i; //利用i控制循環次數
Node *head=(Node *)malloc(sizeof(Node)); //申請頭結點并讓頭指針指向頭結點
Node *p=head; //利用p使當前結點與新節點相連接
srand( (unsigned)time( NULL ) );
for(i=0;i<20;i++) //單鏈表創建
{
p->value=rand()0+1; //生成1~100的隨機數
p->link=(Node *)malloc(sizeof(Node)); //使當前結點與新節點相連
p=p->link; //p指向新節點
}
p->value=rand()0+1; //對尾結點賦值
p->link=NULL;
p=head;
printf("排序前儲存的數值為:"); //打印排序前鏈表儲存的數值
while(p!=NULL)
{
printf("%d ",p->value);
p=p->link;
}
sort(&head,20); //調用排序函數對鏈表排序
p=head;
printf("\n排序后儲存的數值為:"); //打印排序后鏈表儲存的數值
while(p!=NULL)
{
printf("%d ",p->value);
p=p->link;
}
free(head);
return 0;
}
int sort(register Node **head,int length) //定義三個二級指針實現結點交換
{
register Node **prior=head;
register Node **current=&((*prior)->link);
register Node **later=&((*current)->link);
Node *temp1;
Node **temp2;
int i;
for(i=0;i
{
while(later!=NULL)
{
if((*prior)->value>(*current)->value)
{
temp1=*prior; //實現結點交換
*prior=*current;
*current=*later;
*later=temp1;
temp2=current; //調整三個指針的位置
current=later;
later=temp2;
}
if(*later==NULL) //最后一次交換已完成,*later為NULL,不能執行下面代碼,故結束循環
{
break;
}
later=&((*later)->link); //三個指針均向后移動一個結點
current=&((*current)->link);
prior=&((*prior)->link);
}
prior=head; //三個指針均移回鏈表起始處
current=&((*prior)->link);
later=&((*current)->link);
}
}
歡迎光臨 (http://www.zg4o1577.cn/bbs/)
Powered by Discuz! X3.1
主站蜘蛛池模板:
黄色一级大片在线观看
|
国产精品久久久久久久久免费高清
|
久久久www成人免费无遮挡大片
|
av超碰
|
一道本视频
|
奇米av
|
久久久精品视频一区二区三区
|
国产91综合一区在线观看
|
精品综合久久
|
欧美a在线看
|
日本高清视频在线播放
|
免费在线观看一区二区三区
|
少妇精品亚洲一区二区成人
|
久久久国产一区二区三区四区小说
|
国产成人av一区二区三区
|
91精品国产欧美一区二区成人
|
午夜视频在线视频
|
97中文视频
|
欧美一级黄色片在线观看
|
久久精品毛片
|
色久五月
|
亚洲中午字幕
|
欧美专区日韩
|
一区视频
|
精品无码三级在线观看视频
|
成人一级黄色毛片
|
免费成人高清在线视频
|
一本一道久久a久久精品综合蜜臀
|
国产免费一区二区三区免费视频
|
久一久
|
福利社午夜影院
|
天天干天天插天天
|
国产精品久久久久久久久久久久冷
|
欧美日韩亚洲国产综合
|
91av在线免费看
|
亚洲国产网
|
久久综合婷婷
|
久久久av中文字幕
|
日韩二三区
|
日日夜夜天天久久
|
欧美一区二区三区在线看
|