c树结构删除问题

Red_angelX 2011-12-14 12:35:04

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>

const char* playlist[256] = {"111","222","333","44"};


typedef struct node
{
char name[256];
int playtype;
int ucValid;
int sonsize;
struct node* son[12];
struct node* parent;
};

struct node* create(struct node* item)
{
item = (struct node*)malloc(sizeof(struct node));
memset(item,0,sizeof(struct node));
return item;
}


struct node* p_node;
static int num=0;
//删除一个节点
void delete(struct node* item)
{
int i;
//struct node* tmp;
//tmp = create(tmp);
//sprintf(tmp->name,"p_node%d",num++);
//p_node = tmp;
//tmp = item;
for(i=0;i<item->sonsize;i++)
{
delete(item->son[i]);
}

free(item);
item= NULL;
}

void displaynode(struct node* item)
{
printf("============display node info=========\n");
printf("node name : %s\nnode parent :%d\nnode sonsize :%d\n",
item->name,item->parent,item->sonsize);
}

void displaytree(struct node* item)
{
int i;
if(item == NULL)
{
return;
}
for(i=0;i<item->sonsize;i++)
{
if(item->son[i] == NULL)
continue;
printf("--%s addr:0x%x\n",item->son[i]->name,item->son[i]);
if(item->son[i]->sonsize > 0)
{
printf("subnode\n");
displaytree(item->son[i]);
printf("endofsubnode\n");
}
}
}

void move(struct node* parent,struct node* item)
{
int i;
int tmp;
tmp = 0;
parent->son[parent->sonsize++] = item;
item->parent = parent;

//更新parent的ucValid信息
for(i=0;i<parent->sonsize;i++)
{
tmp |= parent->son[i]->ucValid;
}
parent->ucValid = tmp;
}

struct node* buildtree(struct node* root)
{
int i;
struct node* item;

if(root == NULL)
{
printf("error! root is null\n");
}

//创建一级菜单
for(i=0;i<4;i++)
{
item = create(item);
//给name赋值
strcpy(item->name,playlist[i]);
move(root,item);
}

return root;
}

void buildtreeitem(struct node* root)
{
int i;
struct node* item;

//测试代码
for(i=0;i<7;i++)
{
item = create(item);
sprintf(item->name,"item%d",i);
item->playtype = i;
item->ucValid = i%2;
move(root->son[0],item);
}
}



int main(int argc,char** argv)
{
printf("sizeof node :%d\n",sizeof(struct node));
struct node* root;
root = NULL;
root = create(root);
strcat(root->name,"root");
buildtree(root);
buildtreeitem(root);
displaynode(root);
displaytree(root);

//释放
delete(root);
printf("root name :%s\n",root->name);
displaytree(root);
return 0;
}





代码如上,删除函数delete只能删掉第一个节点和第一个子节点,但是如果改成
void delete(struct node* item)
{
int i;
struct node* tmp;
tmp = create(tmp);
//sprintf(tmp->name,"p_node%d",num++);
//p_node = tmp;
tmp = item;
for(i=0;i<tmp->sonsize;i++)
{
delete(tmp->son[i]);
}

free(tmp);
tmp= NULL;
}
貌似就可以删除,但是root节点还是能打印出信息来 不是NULL
另外直接free(root)好像也只free掉了name
请问究竟该怎么写删除代码? 为什么直接free不掉?
...全文
224 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
Red_angelX 2011-12-14
  • 打赏
  • 举报
回复
解决了 楼上正解 谢谢了 分全给你
kongrenxin 2011-12-14
  • 打赏
  • 举报
回复
将delete函数修改一下就可以了,如下:
//删除一个节点
void delete(struct node** item)
{
int i;
for(i=0;i<(*item)->sonsize;i++)
{
delete(&(*item)->son[i]);
}

free(*item);
*item= NULL;
}


再将main函数里调用形式改为delete(&root);即可

之所以要这样改,是因为你本意是想要delete函数里释放指针后,再将其设置为NULL,必须要传递指针的地址进去才能起到作用。
Red_angelX 2011-12-14
  • 打赏
  • 举报
回复
顶一下,分不够可以加
【更新至2025年】2001-2025年上市公司数字化转型年报词频统计(吴非、赵宸宇、甄红线)(300+年报词频统计) 1、时间:2001-2025年 2、来源:上市公司年报 3、参考文献:企业数字化转型与资本市场表现——来自股票流动性的经验证据(吴非) 数字化转型如何影响企业全要素生产率(赵宸宇) 知识产权行政保护与企业数字化转型(甄红线) 4、方法说明:(1)参考吴非老师的做法,对人工智能技术、大数据技术、云计算技术、区块链技术、数字技术运用五个维度76个数字化相关词频进行统计 (2)参考赵宸宇老师的做法,对数字技术应用、互联网商业模式、智能制造、现代信息系统四个维度99个数字化相关词频进行统计 (3)参考甄红线老师的做法,对技术分类、组织赋能、数字化应用等类别下139个数字化相关词频进行统计 5、指标:年份、股票代码、公司简称、行业名称、行业代码、全文-文本总长度、仅中英文-文本总长度、人工智能技术-吴、大数据技术-吴、云计算技术-吴、区块链技术-吴、数字技术运用-吴、数字技术应用-赵、互联网商业模式-赵、智能制造-赵、现代信息系统-赵、技术分类-人工智能技术-甄、技术分类-区块链技术-甄、技术分类-云计算技术-甄、技术分类-大数据技术-甄、组织赋能-人工智能技术-甄、组织赋能-云计算技术-甄、组织赋能-大数据技术-甄、组织赋能-广义数字技术-甄、数字化应用-技术创新-甄、数字化应用-流程创新-甄、数字化应用-业务创新-甄、人工智能、商业智能、图像理解、投资决策辅助系统、智能数据分析、智能机器人、机器学习、深度学习、语义搜索、生物识别技术、人脸识别、语音识别、身份验证、自动驾驶、自然语言处理、大数据、数据挖掘、文本挖掘、数据可视化、异构数据、征信、增强现实、混合现实、虚拟现实、云计算、流计算、图计算、内存计算、多方安全计算、类脑计算、绿色计算、认知计算等300+词频

70,038

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧