| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 401 人关注过本帖
标题:为什么不能查找呢?
只看楼主 加入收藏
小J
Rank: 8Rank: 8
等 级:等待验证会员
威 望:1
帖 子:282
专家分:704
注 册:2009-6-18
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:3 
为什么不能查找呢?
#include "stdio.h"
#include "malloc.h"
typedef struct node{
    int data;
    struct node *next;
}NODE;
NODE *create();
print_data(NODE *);
NODE *find_data(NODE *,int);
NODE *lookup_data(NODE *,int);
main()
{
    int m,n;
    NODE *a,*b,*c;
    a=create();
    print_data(a);
    printf("请输入你要查找的数:");
    scanf("%d",&m);
    b=find_data(a,m);
    if(b!=NULL)
        printf("找到%d!\n",b->data);
    else
        printf("找不到该数!\n");
    printf("请输入你要查找的节点:");
    scanf("%d",&n);
    c=lookup_data(a,n);
    if(c !=NULL)
        printf("该节点的值是:%d\n",c->data);
    else
        printf("输入的节点错误或找不到该数!\n");
}
NODE *create()
{
    int a;
    char str='*';
    NODE *head,*p,*q;
    head=(NODE *)malloc(sizeof(NODE));
    q=head;
    printf("Please input a list:");
    while(str!='\n')
    {
        scanf("%d",&a);
        p=(NODE *)malloc(sizeof(NODE));
        p->data=a;
        q->next=p;
        q=p;
        str=getchar();
    }
    p->next=NULL;
    return head;
}


print_data(NODE *head)
{
    NODE *p;
    p=head->next;
    while (p !=NULL)
    {
        printf("%5d",p->data);
        p=p->next;   
    }
    printf("\n");
}

NODE *find_data(NODE *head,int a)
{
    NODE *p;
    p=head->next;
    while((p!=NULL)&&(p->data!=a));
        p=p->next ;
    return p;
}

NODE *lookup_data(NODE *head,int i)
{
    NODE *p;
    int j=1;
    p=head->next;
    while((p!= NULL)&&(j<i));
    {
        p=p->next;
        j++;
    }
    return p;
}



编译通过,输入数后也能显示,但是查找时出问题!
搜索更多相关主题的帖子: next include create 
2009-10-21 17:16
玩出来的代码
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:河南新乡
等 级:贵宾
威 望:11
帖 子:742
专家分:2989
注 册:2009-10-12
收藏
得分:10 
#include "stdio.h"
#include "malloc.h"
typedef struct node{
    int data;
    struct node *next;
}NODE;
NODE *create();
print_data(NODE *);
NODE *find_data(NODE *,int);
NODE *lookup_data(NODE *,int);
main()
{
    int m,n;
    NODE *a,*b,*c;
    a=create();
    print_data(a);
    printf("请输入你要查找的数:");
    scanf("%d",&m);
    b=find_data(a,m);
    if(b!=NULL)
        printf("找到%d!\n",m);
    else
        printf("找不到该数!\n");
    printf("请输入你要查找的节点:");
    scanf("%d",&n);
    c=lookup_data(a,n);
    if(c!=NULL)
        printf("该节点的值是:%d\n",c->data);
    else  
        printf("输入的节点错误或找不到该数!\n");
}
NODE *create()
{
    int a;
 
    NODE *head,*p,*q;
    head=(NODE *)malloc(sizeof(NODE));
    q=head;
    printf("Please input a list:");
     scanf("%d",&a);
    while(a!=0)
    {
                                               //这里改成这样,你写了两个输入,重复了》》
        p=(NODE *)malloc(sizeof(NODE));
        p->data=a;
        q->next=p;
        q=p;
        scanf("%d",&a);
    }
    p->next=NULL;
    return head;
}
 
 
print_data(NODE *head)
{
    NODE *p;
    p=head->next;
    while (p !=NULL)
    {
        printf("%5d",p->data);
        p=p->next;     
    }
    printf("\n");
}
 
NODE *find_data(NODE *head,int a)
{
    NODE *p;
    p=head->next;
    while((p!=NULL)&&(p->data!=a))
        p=p->next ;
    return p;
}
 
NODE *lookup_data(NODE *head,int i)
{
    NODE *p;
    int j=1;
    p=head->next;
    while((p!= NULL)&&(j<i))
    {
        p=p->next;
        j++;
    }
    return p;
}
 
 
 
稍微的给你改动一下,你没发现每个while()后面都有个;还有几个不太好的地方。。

离恨恰如春草,更行更远还生。
2009-10-21 17:45
小J
Rank: 8Rank: 8
等 级:等待验证会员
威 望:1
帖 子:282
专家分:704
注 册:2009-6-18
收藏
得分:0 
谢谢啦啊!你说的对,我在while()后面多加了;,太不小心了。其实你说那个scanf()是输入数据。而那个getchar()是输入字符。只是当输入回车的时候控制循环跳出的。至于你说的不太好的地方欢迎指出,愿意改正。因为我今天才开始学链表。希望不吝赐教!
2009-10-21 17:57
玩出来的代码
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:河南新乡
等 级:贵宾
威 望:11
帖 子:742
专家分:2989
注 册:2009-10-12
收藏
得分:0 
getchar();你输入一个数他也会当做字符的,含有可能出错,最好在WHILE()循环中用计数循环,这个链表其实我也还有点疑问,我也在看看,你才学,就多看看点实例,多写,我也才学!

离恨恰如春草,更行更远还生。
2009-10-21 18:03
快速回复:为什么不能查找呢?
数据加载中...
 
   



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

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