| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 345 人关注过本帖
标题:为什么符合条件的头结点没有删除?求解决!
只看楼主 加入收藏
小小战士
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:569
专家分:1313
注 册:2012-11-3
结帖率:93.75%
收藏
 问题点数:0 回复次数:5 
为什么符合条件的头结点没有删除?求解决!
图片附件: 游客没有浏览图片的权限,请 登录注册

为什么删除不了偶数数据的头结点?
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define LEN sizeof(struct Shuju)
struct Shuju
{
    int num;
    struct Shuju* next;
};
struct Shuju* creat(void)
{
    srand((unsigned)time(NULL));
    struct Shuju*head;
    struct Shuju*p1,*p2;
    int n=0;
    p1=p2=(struct Shuju*)malloc(LEN);
    p1->num=rand()%100;
    head=NULL;
    while(n<10)
    {
        n=n+1;
        if(n==1)
            head=p1;
        else
            p2->next=p1;
        p2=p1;
        p1=(struct Shuju*)malloc(LEN);
        p1->num=rand()%100;
    }
    p2->next=NULL;
    return(head);
}
int print(struct Shuju* head)
{
    struct Shuju*p;
    p=head;
    if(head!=NULL)
    {
        do
        {
            printf("%3d",p->num);
            p=p->next;
        }while(p!=NULL);
    }
    printf("\n");
    return 0;
}
struct Shuju* del(struct Shuju* head)//删除偶数数据结点
{
    struct Shuju* p;
    struct Shuju* q;
    q=p=head;
    if(head==NULL)
    return 0;
    while(p!=NULL)//不为空进入循环
    {
        if(p->num%2==0)//为偶
        {
            if(p==head)//头数据是偶,删头
            {
                head=head->next;//头结点下一节点
                q=p=head;//p,q指向新的头结点
            }
            else
           {
                q->next=p->next;//q指向下一节点
                p=p->next;//p指向下一结点
            }
        }
        else
        {
            q=p;//q保存p的结点地址
            p=p->next;//p指向下一结点
        }
    }
    return head;
}
int main()
{
    struct Shuju*pt;
    pt=creat();
    printf("初始的10个整数:\n");
    print(pt);
    pt=del(pt);//删偶数据节点
    printf("去偶后的整数:\n");
    print(pt);
    return 0;
}

[ 本帖最后由 小小战士 于 2012-11-24 15:10 编辑 ]
搜索更多相关主题的帖子: head include 
2012-11-24 13:03
小小战士
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:569
专家分:1313
注 册:2012-11-3
收藏
得分:0 
自己解决了!

小小战士,战士中的战斗机!
2012-11-24 15:10
一个孩子
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:5
帖 子:356
专家分:954
注 册:2012-10-1
收藏
得分:0 
改了哪里,我看了一会没看出来~

重要的不是结果,是求一个结果的过程,哪怕千难万难,当你有想要的结果时,你已走的很远
2012-11-24 15:21
一个孩子
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:5
帖 子:356
专家分:954
注 册:2012-10-1
收藏
得分:0 
这个是不带头结点的链表的写法吧?

重要的不是结果,是求一个结果的过程,哪怕千难万难,当你有想要的结果时,你已走的很远
2012-11-24 15:25
小小战士
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:569
专家分:1313
注 册:2012-11-3
收藏
得分:0 
回复 3楼 一个孩子
这个程序是正确的可以得到预想结果的,之前我忘了把del函数中的head返回了

小小战士,战士中的战斗机!
2012-11-24 16:46
小小战士
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:569
专家分:1313
注 册:2012-11-3
收藏
得分:0 
回复 4楼 一个孩子
这个是每个节点都是有效数据节点的写法,没有空闲的头结点

小小战士,战士中的战斗机!
2012-11-24 16:46
快速回复:为什么符合条件的头结点没有删除?求解决!
数据加载中...
 
   



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

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