| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 359 人关注过本帖
标题:单链表删除操作求助
只看楼主 加入收藏
夏小柒
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2013-11-27
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:6 
单链表删除操作求助
各位大神你们好!请大神帮忙看下:
#include<stdio.h>
#include<malloc.h>
#define N 8
struct List
{
    int data;
    struct List *link;
}list;
//建立一个单链表
List *dlbj(int a[],int n)   
{
    List *s,*h;
    int i;
    h=(List *)malloc(sizeof(list));
         h->data=0;
         h->link=NULL;
    for(i=n;i>0;i--)
    {
        s=(List *)malloc(sizeof(list));
          s->data=a[i-1];
          s->link=h->link;
          h->link=s;
    }
    return h;
}
 
//删除函数
struct List *dlbsc(struct List *head,int Q)
{
    struct List *p1,*p2;
    while(head!=NULL)
    {
        p2=head;
        head=head->link;
        free(p2);
    }
    if(head==NULL)
        return NULL;
    p1=head;
    p2=head->link;
    while(p2!=NULL)
    {
        if(p2->data=Q)
        {
            p1->link=p2->link;
            free(p2);
        }
        else
            p1=p2;
        p2=p1->link;
    }
    return head;
}
//主函数
void main()
{
    int a[8]={1,2,11,21,6,5,56,44},n,i;
    a[8]=8;
    int dlbj(int i,int a[]);
    List *h,*p;
     
    printf("The original linklist is:\n");
    for(n=0;n<=N;n++)
        printf("%5d",a[n]);
    printf("\n");
    printf("Please enter the cancel position:\n");
    scanf("%d",&i);
   
    printf("After cancel the linklist is:\n");
    for(n=0;n<=N-1;n++)
        printf("%5d",a[n]);
    printf("\n");
}
能调试,但运行不成功,不知道程序错在哪
小白不胜感激!!
搜索更多相关主题的帖子: include return 
2013-11-27 11:47
pink_duo
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
帖 子:209
专家分:1054
注 册:2013-11-5
收藏
得分:20 
断点调试下

埋头做牛,抬头做人,低头做狗
2013-11-27 16:53
夏小柒
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2013-11-27
收藏
得分:0 
回复 2楼 pink_duo
什么是断点调试呀?刚学C没多久,而且目前没有用过这个断点调试,求大神指点下,,谢谢!!
2013-11-27 17:00
pink_duo
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
帖 子:209
专家分:1054
注 册:2013-11-5
收藏
得分:0 
用VC6.0,里面可以插入断点调试,很有用

埋头做牛,抬头做人,低头做狗
2013-11-27 17:03
夏小柒
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2013-11-27
收藏
得分:0 
回复 4楼 pink_duo
嗯嗯,,谢谢啦!
2013-11-27 17:11
夏小柒
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2013-11-27
收藏
得分:0 
回复 4楼 pink_duo
额,不好意思咯大神,小女子不才,还请大神指点下如何使用这个断点调试
2013-11-27 17:36
四星
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2013-12-26
收藏
得分:0 
#include"stdio.h"
#include"malloc.h"
#define LEN sizeof(struct Student)

struct Student  //Student结构体
{
    int num;        //学号
    char name[10];  //姓名
    char sex;       //性别
    int age;        //年龄
    struct Student *next;
};

int main()
{
    struct Student *creat(void);
    void delete_(int a);
    struct Student *head;
    int a;
    head=creat();
    printf("Please enter the age:\n");
    scanf("%d",&a);
    delete_(a);
}

struct Student *creat(void)
{
    int n=0;
    struct Student *head,*p1,*p2;
//  struct Student *p1,*p2;
//  n=0;
    p1=p2=(struct Student*)malloc(LEN);
    scanf("%d %s %c %d",&p1->num,&p1->name,&p1->sex,&p1->age);   //p1->name前面少了个&号
    //C语言里字符比较严格,如果你前面%d%s没有空格,后面你输入时也不能键入空格,
    //不然空格会自动默认为你的输入,如果你幸运的话,错的地方可能在这里

    printf("\n");
//  printf("\n%d %s %c %d\n",p1->num,p1->name,p1->sex,p1->age);  //显示数据,测试第一次输入是否出错
    head=NULL;
    while(p1->num!=0)
    {
        n=n+1;
        if(n==1)
            head=p1;
        else
            p2->next=p1;
        p2=p1;
        p1=(struct Student*)malloc(LEN);
        scanf("%d %s %c %d",&p1->num,&p1->name,&p1->sex,&p1->age);  //p1->name和p1->sex前面少了个&号
        printf("\n");
//      printf("\n%d %s %c %d\n",p1->num,p1->name,p1->sex,p1->age);  //显示数据,测试第一次输入是否出错
    }
    p2->next=NULL;
    return(head);
}

void delete_(int a)   
{
    struct Student *head,*p1,*p2;
    for(p1=head;p1->next!=NULL;)   //你这个for循环肯定有问题  我就不知怎么给你改
    { //
        if(p1->next->age==a)
        {
            p2=p1->next;
            p1->next=p1->next->next;
            free(p2);
        }
        p1=p1->next;
    }  //这对大括号是我加的
}
也帮我看一下吧
2013-12-28 10:52
快速回复:单链表删除操作求助
数据加载中...
 
   



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

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