| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 501 人关注过本帖
标题:链表初步创建,求前辈指教!
只看楼主 加入收藏
zhangyin
Rank: 2
等 级:论坛游民
帖 子:22
专家分:43
注 册:2011-10-2
结帖率:100%
收藏
已结贴  问题点数:30 回复次数:8 
链表初步创建,求前辈指教!
创建一个链表后,当指定找到num为0 时结束,为何我先输入num,后输入name时 可以,而先输入name ,后输入num时却不能正常结束呢?
#include<stdio.h>
#define LEN  sizeof(struct Node)
#define NULL 0
#include<malloc.h>
typedef struct Node
{
    int num ;
    char name[20] ;
    struct Node *pnext ;
}STU;
STU *creat()
{
    STU *head ;
    STU *p1,*p2 ;
    int N = 0 ;
    head = NULL ;
    p1 = p2 = (STU*)malloc(LEN) ;
    scanf("%s,%d",&p1->name,&p1->num) ;//此句为何不能正常结束?为什么我改成scanf("%d,%s",&p1->num,&p1->name);时可以 正常结束呢?
    while(p1->num !=NULL)             //难道是这里的原因吗,求解!
    {
        N += 1 ;
        if(N == 1)
              head = p1 ;
             else
                p2->pnext  = p1 ;
                p2 = p1 ;
         p1 = (STU*)malloc(LEN) ;
        scanf("%s,%d",&p1->name ,&p1->num) ;         }
    p2->pnext  = NULL ;
    return (head) ;
}
int main(void)
{
    STU *stu ;
    stu = creat() ;
    return 0 ;
}


搜索更多相关主题的帖子: include 
2011-11-05 13:00
非死亡!
Rank: 8Rank: 8
来 自:四川
等 级:蝙蝠侠
帖 子:179
专家分:760
注 册:2011-10-31
收藏
得分:15 
程序代码:
#include<stdio.h>
#define LEN  sizeof(struct Node)
#include <malloc.h>
typedef struct Node
{
    int num ;
    char name[20] ;
    struct Node *pnext ;
}STU;
STU *creat()
{
    STU *head ;
    STU *p1,*p2 ;
    int N = 0 ;
    head = NULL ;
    p1 = p2 = (STU*)malloc(LEN) ;
    scanf("%s%d",p1->name,&p1->num) ;  //name是 数组啊 不加&//此句为何不能正常结束?为什么我改成scanf("%d,%s",&p1->num,&p1->name);时可以 正常结束呢?
    while(N<=10)   //错了,你的无限循环了             //难道是这里的原因吗,求解!
    {
        N += 1 ;
        if(N == 1)
              head = p1 ; 
        else             //改了下 你的好乱啊
          p1 = (STU*)malloc(LEN) ;
          scanf("%s%d",p1->name ,&p1->num) ;  //同上!  不要加逗号好不好
          p2->pnext=p1;
          p2=p1;
     }
    p2->pnext  = NULL ;
    return (head) ;
}
int main(void)
{
    STU *stu ;
    stu = creat() ;
    //用完记得free(head);
    return 0 ;
}


能力 技巧
2011-11-05 13:23
solar009
Rank: 2
等 级:论坛游民
帖 子:10
专家分:11
注 册:2011-10-10
收藏
得分:0 
又学了次单向动态链表
2011-11-05 15:15
zhangyin
Rank: 2
等 级:论坛游民
帖 子:22
专家分:43
注 册:2011-10-2
收藏
得分:0 
回复 2楼 非死亡!
while(N < 10 )只能输入10个数据啊,这样可以但是我是想
用while(p1->num!= 0 )当输入的num 为0 的时候循环应该就会终止的,而不用限定输入的数据的个数!
当这样时scanf("%d%s",&p1->num,p1->name);可以达到目的,而scanf("%s%d",p1->name,&p1->num);就不行了呢。

2011-11-05 20:10
liao06550107
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:2
帖 子:111
专家分:696
注 册:2011-10-2
收藏
得分:15 
程序代码:
#include<stdio.h>
#define LEN  sizeof(struct Node)
#define NULL 0
#include<malloc.h>
typedef struct Node
{
    int num ;
    char name[20] ;
    struct Node *pnext ;
}STU;
STU *creat()
{
    STU *head ;
    STU *p1,*p2 ;
    int N = 0 ;
    head = NULL ;
    p1 = p2 = (STU*)malloc(LEN) ;
    printf("请输入学生学号和姓名中间用逗号隔开!结束输入时请输入0,0\n");//注意输入时的逗号是在英文输入法下
    scanf("%d,%s", &p1->num, p1->name) ;//改为和下一个scanf("%d,%s",&p1->num, p1->name ) 一样格式即可与顺序无关
    while(p1->num != 0)             //改为0
    {
        N += 1 ;
        if(N == 1)
        {
            head = p1 ;
        }
        else
        {
            p2->pnext  = p1 ;
            p2 = p1 ;
        }
        p1 = (STU*)malloc(LEN) ;
        scanf("%d,%s",&p1->num, p1->name ) ;        
    }
    p2->pnext  = NULL ;
    return (head) ;
}
int main(void)
{
    STU *stu ;
    stu = creat() ;
    return 0 ;
}

听不同的音乐,看不同的书,游历不同的城市,邂逅不同的人,走的多了,站的高了,自然就看的远了。
2011-11-05 20:56
zwhgudu1314
Rank: 1
等 级:新手上路
帖 子:22
专家分:7
注 册:2011-3-3
收藏
得分:0 
这个程序错太多了吧。一点思绪都没有乱编。
2011-11-05 22:01
zwhgudu1314
Rank: 1
等 级:新手上路
帖 子:22
专家分:7
注 册:2011-3-3
收藏
得分:0 
看不出是头插法还是尾插法。指针乱指。
2011-11-05 22:07
zhangyin
Rank: 2
等 级:论坛游民
帖 子:22
专家分:43
注 册:2011-10-2
收藏
得分:0 
回复 7楼 zwhgudu1314
我的目的很简单,就是创建一个动态单向链表。至于是否要用到插入,不解,求解。依你看,应该要怎样才会比较好呢?
2011-11-06 12:33
zhangyin
Rank: 2
等 级:论坛游民
帖 子:22
专家分:43
注 册:2011-10-2
收藏
得分:0 
回复 6楼 zwhgudu1314
有哪些错误,真诚地希望你能指出来!
2011-11-06 12:34
快速回复:链表初步创建,求前辈指教!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016073 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved