【发布时间】:2015-07-08 03:49:22
【问题描述】:
我需要将二叉树的值放入数组中,但问题是,我应该只将处于特定深度的值放入数组中。它应该输出插入到数组中的元素数。
我做了这个:
int nivel2_(ABin a, int n, int v[], int level, int *i){
int t;
if(!a) return 0;
if(n == level){
v[(*i)++] = a->value;
return 1;
}else{
t = nivel2_(a->left, n, v, level+1, i) + nivel2_(a->right, n, v, level+1, i);
}
return t;
}
int nivel2(ABin a, int n, int v[]){
int k = 0;
int *i;
i = &k;
return nivel2_(a, n, v, 1, i);
}
由于我将不断递归地更改索引,并且只有当我们达到我们想要的深度时,我才想到使用指针,这样,当递归折叠的一部分发生时,它会将值更改为所有其他折叠过程.有意义吗?
结构:
typedef struct slist
{
int value;
struct slist* next;
} *SList;
typedef struct arvbin* ABin;
typedef struct arvbin
{
int value;
ABin right;
ABin left;
} arvb;
有效吗?
只有当我想要第一级深度的元素时!
这样调用:
nivel2(tree2, 1, v);
完整代码
#include <stdio.h>
#include <stdlib.h>
typedef struct slist
{
int value;
struct slist* next;
} *SList;
typedef struct arvbin* ABin;
typedef struct arvbin
{
int value;
ABin right;
ABin left;
} arvb;
int nivel2_(ABin a, int n, int v[], int level, int *i){
int t;
if(!a) return 0;
if(n == level){
v[(*i)++] = a->value;
return 1;
}else{
t = nivel2_(a->left, n, v, level+1, i) + nivel2_(a->right, n, v, level+1, i);
}
return t;
}
int nivel2(ABin a, int n, int v[]){
int k = 0;
int *i;
i = &k;
return nivel2_(a, n, v, 1, i);
}
void insertTree(ABin *tree, int val){
if((*tree)==NULL){
*tree = (ABin) malloc(sizeof(arvb));
(*tree)->value = val;
(*tree)->left = NULL;
(*tree)->right = NULL;
return;
}
else if(val > (*tree)->value)
{
insertTree(&((*tree)->right), val);
}
else if(val <= (*tree)->value)
{
insertTree(&((*tree)->left), val);
}
return;
}
int main(){
int v[10] = {0};
ABin tree2 = NULL;
insertTree(&tree2, 22);
insertTree(&tree2, 1);
insertTree(&tree2, 3);
nivel2(tree2, 1, v);
int i;
for(i=0; i<5; i++){
printf("%d\n", v[i]);
}
return 0;
}
【问题讨论】:
-
n(nivel2()的第二个参数)应该是什么?除了在递归期间传递它之外,您不会将它用于任何事情。 -
@TedHopp 这是我想要树木元素的关卡
-
嗯。我在想这可能是
v(第三个参数)的容量。或者你的代码可以假设v总是足够大吗? -
考虑到这个练习,我认为我们可以假设 v 足够大。
-
请描述为什么/如何它不起作用。最好提供一个MCVE 来显示问题。也就是说,包括一个 main 设置树并进行相关的函数调用来演示问题。
标签: c arrays binary-tree