数据结构之单链表实例

数据结构之单链表实例:集合元素的添加删除以及求交并集2011-04-2823:30:35|分类:算法学习|字号订阅这个源码是我的数据结构课程设计的源码,呵呵呵,我觉得很不错,附上来留着以后便于使用吧,哈哈哈三百多行啊,呵呵呵,不简单啊,呵呵呵,界面做的还可以,仿照的,哈哈哈#include<stdio.h>#include<conio.h>#include<malloc.h>//单链表结构体的定义typedefstructnode{intdata;//整型structnode*next;}list;//创建链表list*creat(){list*p,*h,*s;inti,n;puts("\nHowmanynumbersdoyouwanttoinputinthelinklist?");scanf("%d",&n);if((h=(list*)malloc(sizeof(list)))==NULL){printf("cannotfindspace!");//没有了足够的内存空间exit(0);}p=h;for(i=0;i<n;i++){if((s=(list*)malloc(sizeof(list)))==NULL){printf("cannotfindspace!");---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---exit(0);}p->next=s;printf("pleaseinput%ddata:",i+1);scanf("%d",&(s->data));//注意,这里一定要取地址!s->next=NULL;p=s;}return(h);}//查找链表中的某个元素,返回该元素list*search(list*h,intdata){list*p;intn;p=h->next;while(p!=NULL){n=p->data;if(n==data)return(p);elsep=p->next;}if(p==NULL)printf("datanotfind!");returnNULL;}//查找链表中的某个元素,返回该元素的前一个元素list*search2(list*h,intdata){if(h==NULL){returnNULL;}---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---list*p,*s;intn;p=h->next;s=h;//s就是p的前一个元素while(p!=NULL){n=p->data;if(n==data)return(s);else{p=p->next;//两个指针都是向后移动s=s->next;}}if(p==NULL)printf("datanotfind!");return0;}//查找链表中的某个元素,返回该元素所在的位置intsearch3(list*h){list*p;intn,position=0,data;p=h->next;printf("Inputthenumberwhichyouwanttofind:\n");scanf("%d",&data);while(p!=NULL){n=p->data;if(n==data){printf("Thedata'spositionis:%d",position+1);return(position+1);}else{p=p->next;position---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---++;---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---}}if(p==NULL){printf("datanotfind!");return0;}return0;}//查找链表中的某个元素,返回是否找到了,1表示找到了0表示没找到intsearch4(list*h,intdata){list*p;intn;p=h->next;while(p!=NULL){n=p->data;if(n==data)return1;elsep=p->next;}if(p==NULL)return0;return0;}//插入某个元素到链表中intinsert(list*p){intn,m,i;list*s,*t;t=p;printf("\nPleaseinputthenumberyouwanttoinsert:");scanf("%d",&n);printf("\nPleaseinputthepositionyouwanttoinsert:");scanf("%d",&---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---m);---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---for(i=0;i<m-1;i++){p=p->next;}if(p==NULL||i>m-1){printf("Cannotfindtheposition!\n");p=t;return0;}if((s=(list*)malloc(sizeof(list)))==NULL){printf("cannotfindspace!");exit(0);}s->data=n;s->next=p->next;p->next=s;return1;}//删除链表中的某个元素,x是前一个元素,y是要删除的元素voiddel(list*h){intdelnum;list*searchpoint,*forepoint;printf("\nInputthenumberyouwanttodelete:\n");scanf("%d",&delnum);if(searchpoint=search(h,delnum)==NULL){return;}else{forepoint=search2(h,delnum);}forepoint->next=searchpoint->next;}//打印出链表中的所有元素---本文来源于网络,仅供参考,勿照抄,如有侵权请联系删除---voidprint(list*h){list*p;p=h->next;printf("\nThelinkedlistis:\n");while(p!=NULL){printf("%d",(p->data));p=p->next;}printf("\n");}//求两个链表的交集intjiaoji(list*list1,list*list2){list*s;intflag=0;s=list1->next;printf("\nThesamenumbersinthetwolinkedlist:");while(s!=NU...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供参考,付费前请自行鉴别。
3、如文档内容存在侵犯商业秘密、侵犯著作权等,请点击“举报”。

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

客服邮箱:

biganzikefu@outlook.com

所有的文档都被视为“模板”,用于写作参考,下载前须认真查看,确认无误后再购买;

文档大部份都是可以预览的,笔杆子文库无法对文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;

文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为依据;

如果您还有什么不清楚的或需要我们协助,可以联系客服邮箱:

biganzikefu@outlook.com

常见问题具体如下:

1、问:已经付过费的文档可以多次下载吗?

      答:可以。登陆您已经付过费的账号,付过费的文档可以免费进行多次下载。

2、问:已经付过费的文档不知下载到什么地方去了?

     答:电脑端-浏览器下载列表里可以找到;手机端-文件管理或下载里可以找到。

            如以上两种方式都没有找到,请提供您的交易单号或截图及接收文档的邮箱等有效信息,发送到客服邮箱,客服经核实后,会将您已经付过费的文档即时发到您邮箱。

注:微信交易号是以“420000”开头的28位数字;

       支付宝交易号是以“2024XXXX”交易日期开头的28位数字。

确认删除?