节点数据打印的格式控制问题

1首先来看下节点数据的结构:

// 整个数据的数据头部分
typedef struct
{
	int nLng;
	int len;        //data指向的区域中已经使用的内存的长度
	int count;      //数据项的数目
	int malloclen;  //data指向的区域有效内存的长度
	char * data;       //指向数据项的内存区域的指针
}TREE, *TREE;
2然后是每个数据项的结构

// 每个数据项结构体的头部
typedef struct
{
	int parent;    //父节点号
	int node;      //本层节点号
	int len;       //文本长度
	char text[0];     //待打印字符串,柔性数组
}ITEM, *ITEM;
3数据存储方式说明

整个存储区域是连续的,data指向某个数据项。

4生成数据项时的编号方式

没有格式控制时的打印方式为:

str1
str2
str3
str4
str5
...
我们想实现如下分层方式;

str1
    str2
    str3
        str4
str5
    str6
...


他们的逻辑关系如下表所示,我们的目的通过这种关系找出每个节点字符串前的缩进次数,如str2和str3缩进一次,对于str4缩进2次。

节点编号

父节点号

节点字符串

1

0

Str1

2

1

Str2

3

1

Str3

4

3

Str4

5

0

Str5

6

5

Str6

5实现方式:通过遍历当前打印节点以上的节点的父节点,直到遇到0,实现函数如下:

int ReturnHigh(char *data)  //该函数返回值为数据项处于第几层(层数即缩进的次数,或空格的次数),data为指向当前数据项头的指针
{
	ITEM *p = (ITEM*)data;
	ITEM *newp = p;
	while (p->parent != 0)
	{
		newp = (ITEM*)((char*)newp - newp->len - sizeof(ITEM));	
		if (newp->node == p->parent)
		{
			return ReturnHigh((char*)newp) + 1;
		}
	}
	if (p->parent == 0)
	{
		return 0;
	}		
}





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值