欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言單鏈表常見(jiàn)操作匯總

 更新時(shí)間:2014年07月04日 17:55:40   投稿:shichen2014  
這篇文章主要介紹了C語(yǔ)言單鏈表常見(jiàn)操作,需要的朋友可以參考下

C語(yǔ)言的單鏈表是常用的數(shù)據(jù)結(jié)構(gòu)之一,本文總結(jié)了單鏈表的常見(jiàn)操作,實(shí)例如下:

#include<stdio.h> 
#include<stdlib.h> 
//定義單鏈表結(jié)構(gòu)體 
typedef int ElemType; 
typedef struct Node 
{ 
ElemType data; 
struct Node *next; 
}LNode,*LinkList; 
//創(chuàng)建單鏈表 
void Build(LinkList L) 
{ 
int n; 
LinkList p,q; 
p=L; 
printf("請(qǐng)輸入n和n個(gè)元素:\n"); 
scanf("%d",&n); 
while(n--) 
{ 
q=(LinkList)malloc(sizeof(LNode)); 
scanf("%d",&q->data); 
q->next = NULL; 
p->next=q; 
p=q; 
} 
} 
//求單鏈表的長(zhǎng)度 
void LinkLength(LinkList L) 
{ 
int num = 0; 
LinkList p; 
p=L->next; 
while(p) 
{ 
num++; 
printf("%3d",p->data); 
p=p->next; 
} 
printf("長(zhǎng)度為:%d",num); 
} 
//查找前驅(qū)結(jié)點(diǎn) 
void Find(LinkList L,int x) 
{ 
LinkList p,q; 
p=L; 
while(p->next &&p->next->data!=x) 
p=p->next; 
if(p->next) 
printf("%d的前驅(qū)結(jié)點(diǎn)為%d",x,p->data); 
else 
printf("沒(méi)有找到"); 
} 
//刪除結(jié)點(diǎn)值為x的元素 
void Delete(LinkList L,int x) 
{ 
LinkList p,q; 
p=L; 
while(p->next && p->next->data!=x) 
p=p->next; 
if(p->next) 
{ 
q=p->next; 
p->next=q->next; 
free(q); 
} 
printf("刪除成功?。?); 
} 
//將表中的元素逆置 
void Reverse(LinkList L) 
{ 
LinkList p,q; 
p=q=L->next; 
L->next=NULL; 
while(p) 
{ 
q=q->next; 
p->next=L->next; 
L->next=p; 
p=q; 
} 
printf("逆置成功?。?); 
} 
//對(duì)單鏈表排序 
void sort(LinkList L) 
{ 
LinkList p,q; 
int temp; 
p=L; 
for(p=L;p->next!=NULL;p=p->next) 
{ 
for(q=p->next;q!=NULL;q=q->next) 
if(p->data>q->data) 
{ 
temp=p->data; 
p->data=q->data; 
q->data=temp; 
} 
} 
printf("排序成功!"); 
} 
//刪除相同元素 
void Deletesameelem(LinkList L) 
{ 
LinkList p,q,s; 
p=L; 
q=L->next; 
while(q->next) 
{ 
if(q->data ==q->next->data) 
{ 
p->next=q->next; 
s=q; 
q=q->next; 
free(s); 
} 
else 
{ 
p=p->next; 
q=q->next; 
} 
} 
printf("刪除成功??!"); 
} 
//在升序鏈表中,插入新的元素,扔有序 
void Insert(LinkList L,LinkList p) 
{ 
LinkList s; 
s=L; 
while(s->next && s->next->data<p->data) 
s=s->next; 
p->next=s->next; 
s->next=p; 
} 
//提示界面顯示 
void Tips() 
{ 
printf("\n"); 
printf("根據(jù)按鍵選擇相應(yīng)的操作:\n"); 
printf("<1>輸出單鏈表及其長(zhǎng)度:\n"); 
printf("<2>查找值為x的直接前驅(qū)結(jié)點(diǎn):\n"); 
printf("<3>刪除值為x的結(jié)點(diǎn):\n"); 
printf("<4>將表中的元素逆置:\n"); 
printf("<5>將單鏈表由小到大進(jìn)行排序:\n"); 
printf("<6>刪除表中相同的元素:\n"); 
printf("<7>在升序鏈表中插入元素x:\n"); 
printf("<0>退出:\n"); 
} 
//主函數(shù) 
void main() 
{ 
int op,x; 
LinkList L,p; 
L = (LinkList)malloc(sizeof(LNode)); 
L->next=NULL; 
L->data=-1; 
Build(L); 
Tips(); 
scanf("%d",&op); 
while(op) 
{ 
switch(op) 
{ 
case 1:LinkLength(L); 
break; 
case 2: 
printf("請(qǐng)輸入要查找的元素x:\n"); 
scanf("%d",&x); 
Find(L,x); 
break; 
case 3: 
printf("請(qǐng)輸入要?jiǎng)h除的元素x:\n"); 
scanf("%d",&x); 
Delete(L,x); 
break; 
case 4:Reverse(L); 
break; 
case 5:sort(L); 
break; 
case 6:Deletesameelem(L); 
break; 
case 7: 
printf("請(qǐng)輸入要插入的元素X:\n"); 
scanf("%d",&x); 
p=(LinkList)malloc(sizeof(LNode)); 
p->data=x; 
Insert(L,p); 
printf("插入成功!!!\n\n"); 
break; 
} 
scanf("%d",&op); 
} 
}

相關(guān)文章

  • C++ 非遞歸實(shí)現(xiàn)二叉樹(shù)的前中后序遍歷

    C++ 非遞歸實(shí)現(xiàn)二叉樹(shù)的前中后序遍歷

    本文將結(jié)合動(dòng)畫和代碼演示如何通過(guò)C++ 非遞歸實(shí)現(xiàn)二叉樹(shù)的前中后序的遍歷,代碼具有一定的價(jià)值,感興趣的同學(xué)可以學(xué)習(xí)一下
    2021-11-11
  • Qt QMessageBox類使用教程

    Qt QMessageBox類使用教程

    QMessageBox類提供一個(gè)模態(tài)對(duì)話框,用于通知用戶或詢問(wèn)用戶一個(gè)問(wèn)題并接收答案。這篇文章主要介紹了QMessageBox的一些常用用法,需要的小伙伴快來(lái)學(xué)習(xí)一下
    2021-12-12
  • C++實(shí)現(xiàn)LeetCode(122.買股票的最佳時(shí)間之二)

    C++實(shí)現(xiàn)LeetCode(122.買股票的最佳時(shí)間之二)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(122.買股票的最佳時(shí)間之二),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++ 中const 類型限定符不兼容問(wèn)題

    C++ 中const 類型限定符不兼容問(wèn)題

    這篇文章主要介紹了C++ 中const 類型限定符不兼容問(wèn)題的相關(guān)資料,需要的朋友可以參考下
    2015-06-06
  • C語(yǔ)言中如何利用循環(huán)嵌套輸出一個(gè)菱形

    C語(yǔ)言中如何利用循環(huán)嵌套輸出一個(gè)菱形

    這篇文章主要介紹了C語(yǔ)言中如何利用循環(huán)嵌套輸出一個(gè)菱形問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單航班管理系統(tǒng)

    C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單航班管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單航班管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • C語(yǔ)言實(shí)現(xiàn)個(gè)人財(cái)務(wù)管理軟件

    C語(yǔ)言實(shí)現(xiàn)個(gè)人財(cái)務(wù)管理軟件

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)個(gè)人財(cái)務(wù)管理軟件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C++與QML進(jìn)行數(shù)據(jù)交互的常見(jiàn)方法總結(jié)

    C++與QML進(jìn)行數(shù)據(jù)交互的常見(jiàn)方法總結(jié)

    這篇文章主要為大家詳細(xì)介紹了C++與QML進(jìn)行數(shù)據(jù)交互的常見(jiàn)方法,文中 的示例代碼講解詳細(xì),具有一定的參考價(jià)值,有需要的小伙伴可以跟隨小編一起了解一下
    2023-10-10
  • QT5實(shí)現(xiàn)電子時(shí)鐘

    QT5實(shí)現(xiàn)電子時(shí)鐘

    這篇文章主要為大家詳細(xì)介紹了QT5實(shí)現(xiàn)電子時(shí)鐘,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • 15種?C++?常見(jiàn)報(bào)錯(cuò)原因分析

    15種?C++?常見(jiàn)報(bào)錯(cuò)原因分析

    這篇文章主要介紹了15種?C++?常見(jiàn)報(bào)錯(cuò),本文通過(guò)實(shí)例代碼給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-01-01

最新評(píng)論