久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 2387|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

利用二級(jí)指針實(shí)現(xiàn)單鏈表相鄰結(jié)點(diǎn)交換

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:125005 發(fā)表于 2016-6-4 01:18 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
利用冒泡法對(duì)單鏈表進(jìn)行排序需要交換兩個(gè)相鄰結(jié)點(diǎn),利用二級(jí)指針可以很方便地解決結(jié)點(diǎn)交換的問題
下面我們生成一個(gè)鏈表,每個(gè)結(jié)點(diǎn)儲(chǔ)存一個(gè)隨機(jī)值,然后對(duì)該鏈表進(jìn)行排序。其中排序算法的實(shí)現(xiàn)過程也同時(shí)實(shí)現(xiàn)了相鄰兩個(gè)結(jié)點(diǎn)的交換。
#include  < stdio.h >
#include < stdlib.h >
#include < time.h >
#define   FALSE 0
#define TRUE 1

typedef struct NODE{ //鏈表節(jié)點(diǎn)的結(jié)構(gòu)體聲明
struct NODE *link;
int value;
}Node;
int sort(register Node **head,int length); //排序函數(shù)的原型聲明

int main(void)
{
int i; //利用i控制循環(huán)次數(shù)
Node *head=(Node *)malloc(sizeof(Node)); //申請(qǐng)頭結(jié)點(diǎn)并讓頭指針指向頭結(jié)點(diǎn)
Node *p=head; //利用p使當(dāng)前結(jié)點(diǎn)與新節(jié)點(diǎn)相連接
srand( (unsigned)time( NULL ) );
for(i=0;i<20;i++) //單鏈表創(chuàng)建
{
p->value=rand()0+1; //生成1~100的隨機(jī)數(shù)
p->link=(Node *)malloc(sizeof(Node)); //使當(dāng)前結(jié)點(diǎn)與新節(jié)點(diǎn)相連
p=p->link; //p指向新節(jié)點(diǎn)
}
p->value=rand()0+1; //對(duì)尾結(jié)點(diǎn)賦值
p->link=NULL;
p=head;  
printf("排序前儲(chǔ)存的數(shù)值為:"); //打印排序前鏈表儲(chǔ)存的數(shù)值
while(p!=NULL)
{
printf("%d ",p->value);
p=p->link;
}  
sort(&head,20); //調(diào)用排序函數(shù)對(duì)鏈表排序
p=head;  
printf("\n排序后儲(chǔ)存的數(shù)值為:"); //打印排序后鏈表儲(chǔ)存的數(shù)值
while(p!=NULL)
{
printf("%d ",p->value);
p=p->link;
}
free(head);
return 0;
}

int sort(register Node **head,int length) //定義三個(gè)二級(jí)指針實(shí)現(xiàn)結(jié)點(diǎn)交換
{
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; //實(shí)現(xiàn)結(jié)點(diǎn)交換
*prior=*current;
*current=*later;
*later=temp1;
temp2=current; //調(diào)整三個(gè)指針的位置
current=later;
later=temp2;
}
if(*later==NULL) //最后一次交換已完成,*later為NULL,不能執(zhí)行下面代碼,故結(jié)束循環(huán)
{
break;
}
later=&((*later)->link); //三個(gè)指針均向后移動(dòng)一個(gè)結(jié)點(diǎn)
current=&((*current)->link);
prior=&((*prior)->link);
}
prior=head; //三個(gè)指針均移回鏈表起始處
current=&((*prior)->link);
later=&((*current)->link);
}
}



評(píng)分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 欧洲精品视频一区 | 日韩国产三区 | 亚洲国产成人av好男人在线观看 | 久久伊人操 | 最新午夜综合福利视频 | 久久69精品久久久久久国产越南 | 伦理二区| 欧美久久久网站 | 人人爱干 | 国产成人av电影 | 国产精品久久久久久久久免费樱桃 | av官网在线 | 国产激情网站 | 久久久久久久久久久高潮一区二区 | 性生生活大片免费看视频 | 超碰超碰| 视频在线h| 国产精品久久影院 | 日韩一区在线观看视频 | 欧美男男videos| 国产亚洲精品一区二区三区 | 国产高潮好爽受不了了夜夜做 | 国产日本精品视频 | 免费一区二区三区在线视频 | 午夜免费福利电影 | 天堂成人国产精品一区 | 国产精品久久久久久婷婷天堂 | 精品在线一区二区 | 亚洲三级在线观看 | 日本一区二区三区免费观看 | 亚洲午夜视频 | 亚洲精品日韩视频 | 91精品国产自产精品男人的天堂 | 天天爽夜夜爽精品视频婷婷 | 91精品国产综合久久久动漫日韩 | 羞羞的视频在线 | 日韩精品成人网 | 一区二区日本 | 国产精品一区二区在线 | 国产伦精品 | av色站|