全局变量和局部变量以及&的问题
2016-05-10 20:46
253 查看
先输入一个字符串 然后求先中后序遍历
http://paste.ubuntu.org.cn/4213378
#include
#include
char w[100];
struct node
{
char data;
struct node *l;
struct node *r;
};
void creat(struct node *&T,char *w) //这里去掉&会无限循环**************
{
char ch;int p;
ch=*w;
if(ch=='\0') p=1;
if(ch==',') {T=NULL;w++;}
else
{
T=(struct node *)malloc(sizeof(struct node));
T->data=ch;
w++;
// printf("%c",T->data);
creat(T->l,w);
creat(T->r,w);
}
}
void travel(struct node *T)
{
if(T)
{
travel(T->l);
printf("%c",T->data);
travel(T->r);
}
}
void travel2(struct node *T)
{
if(T)
{
travel2(T->l);
travel2(T->r);
printf("%c",T->data);
}
}
void travel3(struct node *T)
{
if(T)
{
printf("%c",T->data);
travel3(T->l);
travel3(T->r);
}
}
int main()
{
struct node *head,*T;
scanf("%s",w);
T=NULL;
creat(T,w);
// printf("%c",head->r->data);
travel3(T);
printf("\n");
travel(T);
printf("\n");
travel2(T);
printf("\n");
}
你这样传参不行的,你递归调用的时候对w的++操作是不会影响到外层调用它的函数里的w的,因为你操作的是它的一个拷贝而已
(虽然他们指向的是同一块内存区域,但他们两个指针本身并不是同一个,除非你传二级指针或者一级指针的引用)
PS:我这里用了一个全局的指针
#include <stdio.h>
#include<stdlib.h>
char *w;
struct node
{
char data;
struct node *l;
struct node *r;
};
void creat(struct node *&T)
{
char ch;int p;
ch=*w;
if(ch=='\0') p=1;
if(ch==',')
{
T=NULL;
w++;
}
else
{
T=(struct node *)malloc(sizeof(struct node));
T->data=ch;
w++;
// printf("%c",T->data);
creat(T->l);
creat(T->r);
}
}
void travel(struct node *T)
{
if(T)
{
travel(T->l);
printf("%c",T->data);
travel(T->r);
}
}
void travel2(struct node *T)
{
if(T)
{
travel2(T->l);
travel2(T->r);
printf("%c",T->data);
}
}
void travel3(struct node *T)
{
if(T)
{
printf("%c",T->data);
travel3(T->l);
travel3(T->r);
}
}
int main()
{
struct node *head,*T;
char str[100];
scanf("%s",str);
w = str;
T=NULL;
creat(T);
// printf("%c",head->r->data);
travel3(T);
printf("\n");
travel(T);
printf("\n");
travel2(T);
printf("\n");
}
http://paste.ubuntu.org.cn/4213378
#include
#include
char w[100];
struct node
{
char data;
struct node *l;
struct node *r;
};
void creat(struct node *&T,char *w) //这里去掉&会无限循环**************
{
char ch;int p;
ch=*w;
if(ch=='\0') p=1;
if(ch==',') {T=NULL;w++;}
else
{
T=(struct node *)malloc(sizeof(struct node));
T->data=ch;
w++;
// printf("%c",T->data);
creat(T->l,w);
creat(T->r,w);
}
}
void travel(struct node *T)
{
if(T)
{
travel(T->l);
printf("%c",T->data);
travel(T->r);
}
}
void travel2(struct node *T)
{
if(T)
{
travel2(T->l);
travel2(T->r);
printf("%c",T->data);
}
}
void travel3(struct node *T)
{
if(T)
{
printf("%c",T->data);
travel3(T->l);
travel3(T->r);
}
}
int main()
{
struct node *head,*T;
scanf("%s",w);
T=NULL;
creat(T,w);
// printf("%c",head->r->data);
travel3(T);
printf("\n");
travel(T);
printf("\n");
travel2(T);
printf("\n");
}
你这样传参不行的,你递归调用的时候对w的++操作是不会影响到外层调用它的函数里的w的,因为你操作的是它的一个拷贝而已
(虽然他们指向的是同一块内存区域,但他们两个指针本身并不是同一个,除非你传二级指针或者一级指针的引用)
PS:我这里用了一个全局的指针
#include <stdio.h>
#include<stdlib.h>
char *w;
struct node
{
char data;
struct node *l;
struct node *r;
};
void creat(struct node *&T)
{
char ch;int p;
ch=*w;
if(ch=='\0') p=1;
if(ch==',')
{
T=NULL;
w++;
}
else
{
T=(struct node *)malloc(sizeof(struct node));
T->data=ch;
w++;
// printf("%c",T->data);
creat(T->l);
creat(T->r);
}
}
void travel(struct node *T)
{
if(T)
{
travel(T->l);
printf("%c",T->data);
travel(T->r);
}
}
void travel2(struct node *T)
{
if(T)
{
travel2(T->l);
travel2(T->r);
printf("%c",T->data);
}
}
void travel3(struct node *T)
{
if(T)
{
printf("%c",T->data);
travel3(T->l);
travel3(T->r);
}
}
int main()
{
struct node *head,*T;
char str[100];
scanf("%s",str);
w = str;
T=NULL;
creat(T);
// printf("%c",head->r->data);
travel3(T);
printf("\n");
travel(T);
printf("\n");
travel2(T);
printf("\n");
}
相关文章推荐
- 在没有activity的时候使用getContentResolver方法
- Python读取、保存、查看.mat文件
- hibernate中提倡持久类实现equals()和hashCode()分析
- hdu 1102 Constructing Roads (最小生成树)
- 进程与线程与进程通信BLABLA
- c++构造json数组
- 通过interface的Runnable实现线程合并(join),涉及setName,getName,sleep
- Codeforces Round #169 (Div. 2) E. Little Girl and Problem on Trees(给出一棵树,对距离某个点d范围之内的所有点+x,查询某个点的值)
- 本地组策略的一些安全属性
- 345. Reverse Vowels of a String
- 深刻理解Python中的元类(metaclass)
- 学习总结
- 2016/05/10 thinkphp 3.2.2 ①系统常量信息 ②跨控制器调用 ③连接数据库配置及Model数据模型层 ④数据查询
- POJ 3414 Pots
- leetcode : Counting Bits
- lvs+keepalived实现高可用群集配置详解
- python re.findall 遇到的小问题
- HTTP获取部分内容的范围请求
- DataTable某一列的最大值
- JAVA之路003--if和switch的区别