循环链表

问题:我用的是尾插入法,主要是在输出的时候循环条件不要用错了^^,昨天查资料时遇见了一批“外星人”,今天看循环链表时又遇见“外星人”了**!

贴代码:

#include <iostream>
#include <cstdlib>
 
using namespace std;
 
typedef struct CircleList
{
    int data;
    struct CircleList *next;
}*CList;
 
void createCList(CList &clist)
{
     CList head,node;
     int c;
     clist=(CList)malloc(sizeof(struct CircleList));
     if(!clist)
     {
         cout<<"allocate fail"<<endl;
     }
     else
     {
         clist->next=NULL;
     }
     head=clist;
     scanf("%d",&c);
     while(c!=-1)
     {
         node=(CList)malloc(sizeof(struct CircleList));
         if(!node)
         {
             cout<<"allocate fail"<<endl;
             exit(-1);
         }
         else
         {
         node->data=c;
         node->next=clist;
         head->next=node;
         head=node;
         }
         scanf("%d",&c);
     }
}
 
void displayCList(CList clist)
{
    CList head;
    head=clist;
    while(head->next!=clist)
    {
        head=head->next;
        cout<<head->data<<"->";
    }
    cout<<endl;
}
 
int main()
{
    CList clist;
    cout<<"创建循环链表:"<<endl;
    createCList(clist);
    cout<<"输出循环单链表"<<endl;
    displayCList(clist);
    return 0;
}

 

运行结果:

 

posted @   xshang  阅读(164)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示