鱼C论坛

 找回密码
 立即注册
查看: 2308|回复: 7

[已解决]大佬们看一下我写的输出单链表输出有问题

[复制链接]
发表于 2019-3-29 11:50:26 | 显示全部楼层 |阅读模式

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

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

x
  1. #include<iostream>
  2. #include<cstdlib>
  3. #define N 100
  4. using namespace std;
  5. int n, a[N];

  6. typedef struct LNode {        //定义结构体变量
  7.         int data;
  8.         struct Linknode *next;
  9. }Lnode, *LinkList;
  10. //结构体名称改为LNode,别名改为*LinkList,要不和链名称混淆

  11. void CreatList(LinkList &L,int n) {         //初始化单链表
  12.         LinkList S;
  13.         L = (LinkList)malloc(sizeof(LNode));
  14.         L->next = NULL;                   //设置头结点
  15.         for (int i = n;i >0;--i) {
  16.                 S= (LinkList)malloc(sizeof(LNode));//生成新结点
  17.                 S->data = a[i];              //为单链表赋值
  18.                 S->next = L->next;
  19.                 L->next =S->next;//这里L->next =S;就报错
  20.         }
  21. }

  22. void Displaylist(LinkList &L) {
  23.         LinkList& p = L;
  24.         while( p->data != NULL) {            //打印单链表(感觉就是这有问题 )
  25.                 cout << p->data;
  26.                 p->next= p->next;
  27.         }
  28. }

  29. int main() {
  30.         LinkList L;
  31.         int n;
  32.         cout << "输入个数n";
  33.         cin >> n;
  34.         cout << "依次输入a[]";
  35.         for (int i = 0;i < n;i++)
  36.                 cin >> a[i];
  37.         CreatList(L,n);
  38.         Displaylist(L);
  39.         return 0;
  40. }
复制代码
最佳答案
2019-3-29 22:06:37
本帖最后由 82457097 于 2019-3-29 22:07 编辑

楼主看注释吧 大概改了一下

  1. #include<iostream>
  2. #include<cstdlib>
  3. #define N 100
  4. using namespace std;
  5. int n, a[N];

  6. typedef struct LNode {        
  7.         int data;
  8.         struct LNode *next;//这里是LNode  
  9. }Lnode,*LinkList;




  10. void CreatList(LinkList &L,int n) {         
  11.         LinkList S,T;//多定义一个T当做尾结点,用尾插法生成链表
  12.         L = (LinkList)malloc(sizeof(LNode));
  13.         //L->next = NULL;//这句多余
  14.                 T=L;                  
  15.         for (int i = 0;i <n;i++) {
  16.                 S= (LinkList)malloc(sizeof(LNode));
  17.                 S->data = a[i];            
  18.                 T->next = S; //尾结点移动
  19.                 T =S;
  20.         }
  21.        T->next =NULL;//链表完结 楼主这里没有给链表结尾赋0 导致遍历循环无法退出
  22. }

  23. void Displaylist(LinkList &L)  
  24. {
  25.         LinkList p;
  26.                 p = L->next;//这里p应该越过头结点 不然会读到L->data的数据;
  27.         while( p )
  28.                 {            
  29.                 cout << p->data<<"\n";
  30.                 p = p->next;//这里应该指向下一个结点 p->next=p->next没意义啊;
  31.         }
  32. }

  33. int main() {
  34.         LinkList L;
  35.         int n;
  36.         cout << "输入个数n\n";
  37.         cin >> n;
  38.         cout << "依次输入a[]";
  39.         for (int i = 0;i < n;i++)
  40.                 cin >> a[i];
  41.         CreatList(L,n);
  42.         Displaylist(L);
  43.         return 0;
  44. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-3-29 12:36:12 | 显示全部楼层
p= p->next;
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-3-29 13:52:56 From FishC Mobile | 显示全部楼层
BngThea 发表于 2019-3-29 12:36
p= p->next;

p=p->next就会报错
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-3-29 16:08:47 | 显示全部楼层
本帖最后由 jackz007 于 2019-3-29 16:12 编辑

      我改正了所发现的错误,楼主对照自己的代码参考一下吧。
  1. #include<iostream>
  2. #include<cstdlib>

  3. #define N 100

  4. using namespace std;

  5. int n , a[N] ;

  6. typedef struct LNode {        //定义结构体变量
  7.         int data            ;
  8.         struct LNode * next ;
  9. }LNode , * LinkList         ;

  10. //结构体名称改为LNode,别名改为*LinkList,要不和链名称混淆

  11. LinkList CreatList(void)
  12. {       //初始化单链表
  13.         LinkList head , p1 , p2                                        ;
  14.         int i                                                          ;

  15.         head = NULL                                                    ;
  16.         for(i = 0 ; i < n ; i ++) {
  17.                 if((p2 = (LinkList) malloc(sizeof(LNode))) != NULL) {
  18.                         p2 -> data = a[i]                              ;
  19.                         p2 -> next = NULL                              ;
  20.                         if(! i) head = p2                              ;
  21.                         else p1 -> next = p2                           ;
  22.                         p1 = p2                                        ;
  23.                 } else {
  24.                         cout << "malloc(): 分配节点内存失败!" << endl ;
  25.                         break                                          ;
  26.                 }
  27.         }
  28.         return head                                                    ;
  29. }

  30. void Displaylist(LinkList hd) {
  31.         LinkList p                      ;
  32.         p = hd                          ;
  33.         while(p != NULL) {            //打印单链表(感觉就是这有问题 )
  34.                 cout << p->data << endl ;
  35.                 p = p -> next           ;
  36.         }
  37. }

  38. int main() {
  39.         LinkList head                          ;
  40.         int i                                  ;
  41.         cout << "输入个数 n"                   ;
  42.         cin >> n                               ;
  43.         cout << "依次输入a[]"                  ;
  44.         for (i = 0 ; i < n ; i ++) cin >> a[i] ;
  45.         head = CreatList()                     ;
  46.         Displaylist(head)                      ;
  47. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-3-29 22:06:37 | 显示全部楼层    本楼为最佳答案   
本帖最后由 82457097 于 2019-3-29 22:07 编辑

楼主看注释吧 大概改了一下

  1. #include<iostream>
  2. #include<cstdlib>
  3. #define N 100
  4. using namespace std;
  5. int n, a[N];

  6. typedef struct LNode {        
  7.         int data;
  8.         struct LNode *next;//这里是LNode  
  9. }Lnode,*LinkList;




  10. void CreatList(LinkList &L,int n) {         
  11.         LinkList S,T;//多定义一个T当做尾结点,用尾插法生成链表
  12.         L = (LinkList)malloc(sizeof(LNode));
  13.         //L->next = NULL;//这句多余
  14.                 T=L;                  
  15.         for (int i = 0;i <n;i++) {
  16.                 S= (LinkList)malloc(sizeof(LNode));
  17.                 S->data = a[i];            
  18.                 T->next = S; //尾结点移动
  19.                 T =S;
  20.         }
  21.        T->next =NULL;//链表完结 楼主这里没有给链表结尾赋0 导致遍历循环无法退出
  22. }

  23. void Displaylist(LinkList &L)  
  24. {
  25.         LinkList p;
  26.                 p = L->next;//这里p应该越过头结点 不然会读到L->data的数据;
  27.         while( p )
  28.                 {            
  29.                 cout << p->data<<"\n";
  30.                 p = p->next;//这里应该指向下一个结点 p->next=p->next没意义啊;
  31.         }
  32. }

  33. int main() {
  34.         LinkList L;
  35.         int n;
  36.         cout << "输入个数n\n";
  37.         cin >> n;
  38.         cout << "依次输入a[]";
  39.         for (int i = 0;i < n;i++)
  40.                 cin >> a[i];
  41.         CreatList(L,n);
  42.         Displaylist(L);
  43.         return 0;
  44. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-4-2 10:04:26 | 显示全部楼层
82457097 发表于 2019-3-29 22:06
楼主看注释吧 大概改了一下

前辈,我想问一下while(p->next!= NULL)和while(p)有什么不同?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-4-2 11:53:02 From FishC Mobile | 显示全部楼层
不要叫前辈 我也是初学者
我觉得没有什么不同 p和p->next指向的是同一个地址 不过p看起来简洁一些嘛
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-4-2 11:53:32 From FishC Mobile | 显示全部楼层
不要叫前辈 我也是初学者
我觉得没有什么不同 p和p->next指向的是同一个地址 不过p看起来简洁一些嘛
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-4 15:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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