| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
共有 410 人关注过本帖
标题:链表问题
只看楼主 加入收藏
刘暮哲
Rank: 2
来 自:江苏
等 级:论坛游民
帖 子:75
专家分:83
注 册:2009-9-25
结帖率:69.23%
收藏
已结贴  问题点数:6 回复次数:5 
链表问题
#include<stdio.h>
#include<stdlib.h>
#define null 0
#define n 9
struct  list
{
    int number;
    struct  list *next;
};
struct  list *node;
int key;
void create(list *node);

void *insert(list *node,int key);
void print(list *node);

void main()
{
    list *head;
   
    head=(list *)malloc(sizeof(list));
   
    create(head);
    print(head);

    printf("\n------------------------------------------------------\n");
    insert(head,n);
    print(head);

}


void create(list *node)
{

    printf("(nter the number -999 to end)********");
    scanf("%d",&node->number);
    if(node->number==-999)
    {
        node->next=null;
    }
    else        
    {   
        node->next=(list *)malloc(sizeof(list));
        create(node->next);
    }
    return;
}

void *insert(list *node,int key)
{
     struct  list *h;
     while(node->next!=null)
      {
        
      
      
        if(node->number<=key&&node->next->number>=key)
           {
              printf("ok find it and prepare insert it\n");
              h=(list *)malloc(sizeof(list));
              h->number=key;
              node->next=h;
              h->next=node->next->next;
              
           }
       insert(node->next,key);
      }
     
   
    return;
}
            
void print(list *node)
{
    if(node->next!=null)
    {
       printf("%d-->",node->number);
       if(node->next->next==null)
            printf("%d",node->next->number);
   
       print(node->next);
    }
    return;
}

运行结果是这样的
 
图片附件: 游客没有浏览图片的权限,请 登录注册

肯定是红色部分插入函数的错误  希望大家帮我看看什么原因  谢谢!
2009-11-07 16:25
lijm1989
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:珠海
等 级:贵宾
威 望:12
帖 子:675
专家分:2844
注 册:2009-10-14
收藏
得分:1 
没看懂LZ的意思···
2009-11-07 18:16
jackwain
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:168
专家分:134
注 册:2009-3-21
收藏
得分:1 
不知道你用的是哪个编译器
结构体声明指针只用一个list
我在vc 6.0 dev-c++都无法通过
2009-11-07 20:35
兜里有糖糖
Rank: 1
等 级:新手上路
帖 子:3
专家分:1
注 册:2009-4-18
收藏
得分:1 
有问题莫?
2009-11-07 21:22
刘暮哲
Rank: 2
来 自:江苏
等 级:论坛游民
帖 子:75
专家分:83
注 册:2009-9-25
收藏
得分:0 
我的意思就是建立一个链表  再插入一个数  显示新链表

做最好的自己
2009-11-08 10:46
lansong
Rank: 4
等 级:业余侠客
帖 子:79
专家分:226
注 册:2009-6-11
收藏
得分:1 
自己对比一下

#include<stdio.h>
#include<stdlib.h>
#define null 0
#define n 9
struct  list
{
    int number;
    struct  list *next;
};
struct  list *node;
int key;
void create(list *node);

void *insert(list *node,int key);
void print(list *node);

void main()
{
    list *head;
   
    head=(list *)malloc(sizeof(list));
   
    create(head);
    print(head);

    printf("\n------------------------------------------------------\n");
    insert(head,n);
    print(head);

}


void create(list *node)
{

    printf("(nter the number -999 to end)********");
    scanf("%d",&node->number);
    if(node->number==-999)
    {
        node->next=null;
    }
    else        
    {   
        node->next=(list *)malloc(sizeof(list));
        create(node->next);
    }
    return;
}

void *insert(list *node,int key)
{
     struct  list *h;
     while(node->next!=null)
      {
        
      
      
        if(node->number<=key&&node->next->number>=key)
           {
              printf("ok find it and prepare insert it\n");
              h=(list *)malloc(sizeof(list));
              h->number=key;
              h->next=node->next;
              node->next=h;
              
              break;
              
           }
       node = node->next;
      }
     
   
    return (void*)h;
}
            
void print(list *node)
{
    if(node->next!=null)
    {
       printf("%d-->",node->number);
       if(node->next->next==null)
            printf("%d",node->next->number);
   
       print(node->next);
    }
    return;
}
2009-11-08 11:52
快速回复:链表问题
数据加载中...
 
   



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

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.020251 second(s), 10 queries.
Copyright©2004-2025, BC-CN.NET, All Rights Reserved