| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 447 人关注过本帖
标题:这个内存的的控制难道头了,哪位路过指点指点
只看楼主 加入收藏
战斗!立
Rank: 2
等 级:论坛游民
帖 子:29
专家分:43
注 册:2011-11-26
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:1 
这个内存的的控制难道头了,哪位路过指点指点
#include <stdio.h>
#include <stdlib.h>

typedef struct node
{
    int item;
    struct node* next;
} NODE;

NODE *insert(NODE *head, int num);
NODE *search(NODE *head, int num);
void destroy(NODE *head);
int main()
{
    NODE *head = NULL, *p;
    int num;
    while(scanf("%d", &num)!=EOF) {
        head = insert(head, num);
    }

    for(p=head;p!=NULL;p=p->next) {
        printf("%d ", p->item);
    }
    printf("\n");

    int count=0;
    for(p=head;p!=NULL;p=p->next) {
        if((p=search(p, 100))!=NULL) count++;
        else break;
    }
    printf("num of 100 is %d.\n", count);

    destroy(head);
}

NODE *insert(NODE *head, int num)
{
    NODE *p = malloc(sizeof(NODE));
    if(p == NULL) {printf("error!\n");exit(1);}
    p->item = num;
    p->next = head;
    return p;
}

NODE *search(NODE *head, int num)
{
    NODE *p;
    for(p=head;p!=NULL;p=p->next) {
        if(p->item == num) break;
    }
    return p;
}

void destroy(NODE *head)
{
    NODE *p,*q;
    for(p=head;p!=NULL;p=q) {
        q=p->next;
        free(p);
    }
}

在这个程序中作进一步改进
要求实现函数delete从链表中摘除用search找到的节点,最后调用free释放它的存储空间
搜索更多相关主题的帖子: 免费 内存 include 会员 资料 
2011-12-01 21:50
embed_xuel
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:58
帖 子:3845
专家分:11385
注 册:2011-9-13
收藏
得分:14 
前面写了那么多了,自己接着写呗

总有那身价贱的人给作业贴回复完整的代码
2011-12-01 21:53
快速回复:这个内存的的控制难道头了,哪位路过指点指点
数据加载中...
 
   



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

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