科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道应用软件c语言最经典的链表

c语言最经典的链表

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文介绍经典的链表的实现代码。

作者:中国协议网 来源:中国协议网 2007年9月15日

关键字: C语言 链表 软件

  • 评论
  • 分享微博
  • 分享邮件
在turbo c 2.0 下调试通过.(把汉语注释去掉)

#include"stdio.h"
#include"malloc.h"
#define NULL 0
#define L sizeof(struct integer)
struct integer                           /*定义结构体*/
{
int num;
int zhengshu;
    struct integer *next;
};
int n;   //纪录链表的长度
struct integer *creat(void)             /*创建链表*/
{
    struct integer *head;
    struct integer *p1,*p2;
    n=0;
    p1=p2=(struct integer *)malloc(L);
    scanf("%d,%d",&p1->num,&p1->zhengshu);
    head=NULL;
    while(p1->num!=0)
{
n=n+1;
        if(n==1) head=p1;
        else p2->next=p1;
        p2=p1;
        p1=(struct integer *)malloc(L);
        scanf("%d,%d",&p1->num,&p1->zhengshu);
}
    p2->next=NULL;
    return(head);
}

void print(struct integer *head)    /*打印链表中的数据*/
{
    struct integer *p;
    printf("Now %d biaohao and zhengshu are :n",n);
    p=head;
    if(head!=NULL)
    do
     {printf("%d,%5.1dn",p->num,p->zhengshu);
      p=p->next;
     }while(p!=NULL);
}

int count(struct integer *head)   /*返回链表的长度*/
{
int i=0;
    struct integer *p;
p=head;
while(p!=NULL)
{
p=p->next;i++;
}
return i;
}

void *findnode(struct integer *head,int num)  /*查找链表中的第num个数据*/
{
int j=1;
struct integer *p;
/*if(head==NULL)
{
printf("n空链表,请先创建!n");
return;
}*/
p=head;
if(num>count(head)||num<=0)
{
printf("Input error! Please input againn");
}
else
{
while(p!=NULL && jnext;
}
printf("%d bianhao reprensts %dn",p->num,p->zhengshu);
printf("n");
}
return(head);
}


struct integer *del(struct integer *head,long num)  /*删除链表中的第num个数据*/
{
struct integer *p1,*p2;
    if(head==NULL)
{
printf("nList Null!n");
        return;
}
    p1=head;
    while(num!=p1->num && p1->next!=NULL)
{
        p2=p1;
        p1=p1->next;
}
    if(num==p1->num)
    {
        if(p1==head) head=p1->next;
        else p2->next=p1->next;
        printf("Delete: %dn",num);
        n=n-1;
    }
    else printf("%d not been fonnd!n",num);
    return(head);
}

struct integer *insert(struct integer *head,struct integer *stud)  /*插入数据*/
{
    struct integer *p0,*p1,*p2;
    p1=head;
    p0=stud;
    if(head==NULL)
{
head=p0;
        p0->next=NULL;
}
    else
{
while((p0->num>p1->num)&&(p1->next!=NULL))
{
p2=p1;
            p1=p1->next;
}
if(p0->num<=p1->num)
{
            if(head==p1)head=p0;
            else p2->next=p0;
            p0->next=p1;
}
        else
{
            p1->next=p0;
            p0->next=NULL;
}
}
    n=n+1;
    return(head);
}

main()  /*主功能函数*/
{
int a,b;
    struct integer *head,stu;
    int del_num,fin_num;
printf("1 to go on / 0 to exit:n");
scanf("%d",&a);
while(a!=0)
{
/*struct integer *head,stu;
        int del_num;*/
printf("1 creat 2 print 3 delete 4 insert 5 findonde 0 exitn");
/*菜单的实现*/
scanf("%d",&b);
switch(b)
{
case 1:
{
/*clrscr();*/
printf("Please Input bianhao and data:n");
printf("for example 1,90  0,0 to exit:n");
head=creat();
}break;
case 2:
{
/*clrscr();*/
print(head);
}break;
case 3:
{
/*clrscr();*/
    printf("nInput the deleted biaohao:");
    scanf("%d",&del_num);
    head=del(head,del_num);
}break;
        case 4:
{
/*clrscr();*/
                printf("nInput the inserted biaohao and zhengshu:");
                scanf("%d,%d",&stu.num,&stu.zhengshu);
                head=insert(head,&stu);
}break;
        case 5:
{
/*clrscr();*/
printf("Please Input the bianhao you want to find:");
scanf("%d",&fin_num);
head=findnode(head,fin_num);
}break;
case 0:
{
     return;
}break;
default:
printf("Input error! Please input againn");
}
}
 
}

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    闂傚倸鍊风欢锟犲矗鎼淬劌绐楅柡鍥╁亹閺嬪酣鏌曡箛瀣仾濠殿垰銈搁弻鏇$疀鐎n亖鍋撻弽顓ㄧ稏闁跨噦鎷�

    婵犵數濮烽。浠嬪焵椤掆偓閸熷潡鍩€椤掆偓缂嶅﹪骞冨Ο璇茬窞闁归偊鍓涢悾娲⒑闂堟单鍫ュ疾濠婂嫭鍙忔繝濠傜墛閸嬨劍銇勯弽銊с€掗柟钘夊暣閺岀喖鎮滈埡鍌涚彋閻庤娲樺畝绋跨暦閸洖鐓涢柛灞剧矋濞堟悂姊绘担绛嬪殐闁搞劋鍗冲畷銏ゅ冀椤愩儱小闂佹寧绋戠€氼參宕伴崱妯镐簻闁靛牆鎳庢慨顒€鈹戦埥鍡椾簼婵犮垺锚铻炴俊銈呮噺閸嬪倹绻涢崱妯诲碍閻庢艾顦甸弻宥堫檨闁告挾鍠庨锝夘敆娓氬﹦鐭楁繛鎾村焹閸嬫捇鏌e☉娆愬磳闁哄本绋戦埞鎴﹀川椤曞懏鈻婄紓鍌欑劍椤ㄥ懘鎯岄崒鐐靛祦閹兼番鍔岄悞鍨亜閹烘垵顏╅悗姘槹閵囧嫰寮介妸褎鍣ョ紓浣筋嚙濡繈寮婚悢纰辨晣鐟滃秹鎮橀懠顒傜<閺夊牄鍔庣粻鐐烘煛鐏炶姤鍠橀柡浣瑰姍瀹曠喖顢橀悩铏钒闂備浇宕垫慨鎶芥⒔瀹ュ鍨傞柦妯猴級閿濆绀嬫い鏍ㄧ☉濞堟粓姊虹涵鍛【妞ゎ偅娲熼崺鈧い鎺嗗亾闁挎洩濡囧Σ鎰板籍閸繄顓洪梺缁樺姇瀵剙螖閸涱喚鍘搁梺鍓插亽閸嬪嫰鎮橀敃鍌涚厱閻庯綆鍋嗘晶顒傜磼閸屾稑绗ч柟鐟板閹煎湱鎲撮崟闈涙櫏闂傚倷绀侀幖顐も偓姘卞厴瀹曞綊鏌嗗鍛紱閻庡箍鍎遍ˇ浼村磿瀹ュ鐓曢柡鍥ュ妼婢ь垰霉閻樿秮顏堟箒闂佹寧绻傚Λ妤呭煝閺囥垺鐓冪憸婊堝礈濮樿泛钃熼柕濞у嫷鍋ㄩ梺缁樺姇椤曨參鍩㈤弴銏″€甸柨婵嗗€瑰▍鍥ㄣ亜韫囨稐鎲鹃柡灞炬礋瀹曢亶顢橀悢濂変紦

    重磅专题
    往期文章
    最新文章