鱼C论坛

 找回密码
 立即注册
查看: 1694|回复: 2

[已解决]在写循环链表的插入时 一直无法实现循环 链表都构建不了

[复制链接]
发表于 2020-3-17 23:52:12 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
帮帮孩子吧
孩子真不行了
这个程序不知道为什么就是构建不了
运行时插入一个元素后便进行不下去
什么也不显示 之后便退出了

程序如下:
#include<stdio.h>
#include<stdlib.h>

struct line
{
        int liner;
        struct line *next;
};


void getinput(struct line *newletter)//向新节点中输入元素
{

        printf("请输入元素:");
    scanf("%d",(*newletter).liner);       
       
}
void printletter(struct line *letter)
{
        struct line *newletter;
       
        newletter=letter;

        while(newletter->next!=letter)
        {
                printf("%d\n",newletter->liner);

                newletter=newletter ->next;

        }
}



void freeletter(struct line **letter)//释放空间
{
        struct line *temp;
        while(letter!=NULL)
        {
                temp =*letter;
                *letter= (*letter)->next;       
                free(temp);
        }
}

void addline(struct line **letter)//插入新节点
{
        int i;
        struct line *newletter,*temp;
       

        printf("输入你想输入的值,当输入0时结束输入\n");

        while(1)//小甲鱼在带你学c带你飞中讲的循环
        {
                scanf("%d",&i);

                if(i==0)break;
               
                if((*letter)=NULL)
                {
                        (*letter)=(struct line *)malloc(sizeof(struct line));
                        if(!(*letter))
                                exit(0);
                        (*letter)->liner=i;
                        (*letter)->next=*letter;
                }
                else
                {
                        for(temp=(*letter);temp->next !=(*letter);temp=temp->next)
                                ;

                        newletter=(struct line *)malloc(sizeof(struct line));

                        if(!newletter)
                                exit(0);

                        newletter->liner=i;

                        newletter->next=(*letter);

                        temp->next=newletter;
                }

        }
}

void insert(struct line **letter,int i)//插入函数
{
        struct line *temp,*last,*target,*p;
        int item,j=1;

        printf("请输入你想插入的值:");
        scanf("%d",&item);

        if(i==1)
        {
                temp=(struct line *)malloc(sizeof(struct line));
                temp->liner = item;
                for(last=(*letter);last->next!=(*letter);last=last->next);

                last->next=temp;
                temp->next=(*letter);
        }
        else
        {
                target = (*letter);
                for(;j<i-1;++j)
                {
                        target->next;
                }
                temp=(struct line *)malloc(sizeof(struct line));
                temp->liner = item;
                p=target->next;
                target->next=temp;
                temp->next=p;

        }

}
int find(struct line *letter,int elem)//寻找到想插入位置的函数
{
        struct line *target;
        int i=1;

        for(target=letter;target->liner!=elem&&target->next!=letter;++i)
        {
                target = target->next;
        }
        if(target->next==letter)
        {return 0;}
        return i;
}

int main()
{
        struct line *letter ;
        int ch,h,t;

        printf("请输入你想插入的链表数值\n");


        addline(&letter);


        printf("是否打印Y/N :");
        do
        {
                ch=getchar();
        }while(ch!='Y'&&ch!='N');
        if(ch=='Y')
        {
                printletter(letter);
        }



        printf("你想插入到那个元素之后:");
        scanf("%d",&t);

        h=find(letter,t);
        insert(&letter,h);
        printf("是否打印Y/N :");
        do
        {
                ch=getchar();
        }while(ch!='Y'&&ch!='N');
        if(ch=='Y')
        {
                printletter(letter);
        }



        freeletter(&letter);


        return 0;
}
最佳答案
2020-3-18 00:19:26
  1. #include<stdio.h>
  2. #include<stdlib.h>

  3. struct line
  4. {
  5.         int liner;
  6.         struct line *next;
  7. };


  8. void getinput(struct line *newletter)//向新节点中输入元素
  9. {

  10.         printf("请输入元素:");
  11.     scanf("%d",(*newletter).liner);        
  12.         
  13. }
  14. void printletter(struct line *letter)
  15. {
  16.         struct line *newletter;
  17.         
  18.         newletter=letter;

  19.         while(newletter->next!=letter)
  20.         {
  21.                 printf("%d\n",newletter->liner);

  22.                 newletter=newletter ->next;

  23.         }
  24.                  printf("%d\n",newletter->liner);
  25. }

  26. void addline(struct line **letter)//插入新节点
  27. {
  28.         int i;
  29.         struct line *newletter,*temp;
  30.         

  31.         printf("输入你想输入的值,当输入0时结束输入\n");

  32.         while(1)//小甲鱼在带你学c带你飞中讲的循环
  33.         {
  34.                 scanf("%d",&i);

  35.                 if(i==0)break;
  36.                
  37.                 if((*letter)==NULL) // ==
  38.                 {
  39.                         (*letter)=(struct line *)malloc(sizeof(struct line));
  40.                         if(!(*letter))
  41.                                 exit(0);
  42.                         (*letter)->liner=i;
  43.                         (*letter)->next=*letter;
  44.                 }
  45.                 else
  46.                 {
  47.                         for(temp=(*letter);temp->next !=(*letter); temp=temp->next);

  48.                         newletter=(struct line *)malloc(sizeof(struct line));

  49.                         if(!newletter)
  50.                                 exit(0);

  51.                         newletter->liner=i;

  52.                         newletter->next=(*letter);

  53.                         temp->next=newletter;
  54.                 }

  55.         }
  56. }


  57. int main()
  58. {
  59.         struct line *letter=NULL ;
  60.         int ch,h,t;

  61.         printf("请输入你想插入的链表数值\n");


  62.         addline(&letter);


  63.         printf("是否打印Y/N :");
  64.         do
  65.         {
  66.                 ch=getchar();
  67.         }while(ch!='Y'&&ch!='N');
  68.         if(ch=='Y')
  69.         {
  70.                 printletter(letter);
  71.         }


  72.         return 0;
  73. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-3-18 00:19:26 | 显示全部楼层    本楼为最佳答案   
  1. #include<stdio.h>
  2. #include<stdlib.h>

  3. struct line
  4. {
  5.         int liner;
  6.         struct line *next;
  7. };


  8. void getinput(struct line *newletter)//向新节点中输入元素
  9. {

  10.         printf("请输入元素:");
  11.     scanf("%d",(*newletter).liner);        
  12.         
  13. }
  14. void printletter(struct line *letter)
  15. {
  16.         struct line *newletter;
  17.         
  18.         newletter=letter;

  19.         while(newletter->next!=letter)
  20.         {
  21.                 printf("%d\n",newletter->liner);

  22.                 newletter=newletter ->next;

  23.         }
  24.                  printf("%d\n",newletter->liner);
  25. }

  26. void addline(struct line **letter)//插入新节点
  27. {
  28.         int i;
  29.         struct line *newletter,*temp;
  30.         

  31.         printf("输入你想输入的值,当输入0时结束输入\n");

  32.         while(1)//小甲鱼在带你学c带你飞中讲的循环
  33.         {
  34.                 scanf("%d",&i);

  35.                 if(i==0)break;
  36.                
  37.                 if((*letter)==NULL) // ==
  38.                 {
  39.                         (*letter)=(struct line *)malloc(sizeof(struct line));
  40.                         if(!(*letter))
  41.                                 exit(0);
  42.                         (*letter)->liner=i;
  43.                         (*letter)->next=*letter;
  44.                 }
  45.                 else
  46.                 {
  47.                         for(temp=(*letter);temp->next !=(*letter); temp=temp->next);

  48.                         newletter=(struct line *)malloc(sizeof(struct line));

  49.                         if(!newletter)
  50.                                 exit(0);

  51.                         newletter->liner=i;

  52.                         newletter->next=(*letter);

  53.                         temp->next=newletter;
  54.                 }

  55.         }
  56. }


  57. int main()
  58. {
  59.         struct line *letter=NULL ;
  60.         int ch,h,t;

  61.         printf("请输入你想插入的链表数值\n");


  62.         addline(&letter);


  63.         printf("是否打印Y/N :");
  64.         do
  65.         {
  66.                 ch=getchar();
  67.         }while(ch!='Y'&&ch!='N');
  68.         if(ch=='Y')
  69.         {
  70.                 printletter(letter);
  71.         }


  72.         return 0;
  73. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-18 21:02:26 | 显示全部楼层
本帖最后由 高光远 于 2020-3-18 21:05 编辑


那里少了一个=所以无法进行判定
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-1 00:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表