• 手机版

    扫码体验手机版

  • 微信公众号

    扫码关注公众号

国内首家协议开发

软芯音视解码保护平台

在线
客服

发布
需求

在线
聊天

天盟
APP

天盟APP下载

关注
微信

微信扫一扫访问
顶部

用C语言编写一个算法

建立一个循环单链表,其节点有prior,data和next三个域,其中data为数据域,存放元素的有效信息,next为指针域,指向后继节点,prior为指针域,它的值为NULL。编写一个算法将此表改为循环双链表。

免责声明:本内容仅代表回答会员见解不代表天盟观点,请谨慎对待。

版权声明:作者保留权利,不代表天盟立场。

使用道具 举报

全部参与1

//main.c--双向循环链表,带头结点#include#includetypedefcharElemType;typedefstructDuLNode{ElemTypedata;structDuLNode*prior;structDuLNode*next;}DuLNode,*DuLinkList;#defineNUM26intInitList(DuLinkList*L,intn);voidTraverseList(DuLinkListL,inti);voidDestroyList(DuLinkList*L);intmain(intargc,charconst*argv[]){DuLinkListL=NULL;InitList(&L,NUM);printf("L=0x%x\n",L);//printf("%c\n",L->data);TraverseList(L,3);printf("L=0x%x\n",L);//printf("%c\n",L->data);DestroyList(&L);printf("L=0x%x\n",L);printf("\nBye!\n");return0;}intInitList(DuLinkList*L,intn){inti;DuLinkListp;//保存尾结点DuLinkListq;//保存每次新建的结点*L=(DuLinkList)malloc(sizeof(DuLNode));if(!(*L)){return0;}(*L)->data='#';(*L)->prior=(*L)->next=NULL;p=*L;for(i=0;idata='A'+i;q->prior=p;q->next=p->next;p->next=q;p=q;}//+---++---++---++---++---++---+//NULLNULL//+---++---++---++---++---++---+//*Lpif((*L)->next!=NULL){(*L)->next->prior=p;p->next=(*L)->next;}//___________________________________//↑↓//+---++---++---++---++---++---+//NULL|N|//+---++---++---++---++---++---+//↑___________________________________↓//*Lpreturn1;}voidTraverseList(DuLinkListL,inti){intj;DuLinkListp;if(!L){return;}if(L->next==NULL){return;}p=L->next;if(i>0){do{p=p->next;}while(--i);}if(iprior;}while(++i);}for(j=0;jdata);p=p->next;}printf("\n");}voidDestroyList(DuLinkList*L){//DuLinkListhead=(*L)->next;//DuLinkListp=(*L)->next;//DuLinkListq;//do//{//q=p->next;//printf("free%c",p->data);//free(p);//p=q;//}while(p!=head);//printf("free%c\n",(*L)->data);//free(*L);//*L=NULL;DuLinkListrear;DuLinkListp;if((*L)->next!=NULL){rear=(*L)->next->prior;while((*L)!=rear){p=(*L)->next;printf("free%c",(*L)->data);free(*L);*L=p;}}printf("free%c\n",(*L)->data);free(*L);*L=NULL;}

使用道具 举报

发新帖

发布任务需求已有1031168位用户正在使用天盟网服务

发布分类: *
任务预算: *
需求内容: *
手机号码: *
任务商家报价为
  • 预算价 :
  • 成交价 :
  • 完工期 :
  • 质保期 :

* 最终任务项目以服务商报价、双方协商为准!