求大佬帮一下忙
英文和数字输出没问题,汉字输出就有问题,比如说,一句话,一个字输出了下一个字就不输出了。 {:10_250:} 求大佬帮帮忙 应该是你的开发环境问题,把你的代码贴上来,我在这边试试#include<stdio.h>
#include<malloc.h>
#defineMaxSize 50
typedef char elemtype;
typedef struct node
{ elemtype data; // 结点的值
struct node *lchild,*rchild; // 左右孩子指针
}BTNode;
void CreateBTNode(BTNode *&b,char *str) /*由str串创建二叉链*/
{
BTNode *St,*p=NULL;
int top=-1,k,j=0;
char ch;
b=NULL; /*建立的二叉树初始时为空*/
ch=str;
while (ch!='\0') /*str未扫描完时循环*/
{
switch(ch)
{
case '(':top++;St=p;k=1; break; /*为左结点*/
case ')':top--;break;
case ',':k=2; break; /*为右结点*/
default:p=(BTNode *)malloc(sizeof(BTNode));
p->data=ch;p->lchild=p->rchild=NULL;
if (b==NULL) /*p指向二叉树的根结点*/
b=p;
else /*已建立二叉树根结点*/
{
switch(k)
{
case 1:St->lchild=p;break;
case 2:St->rchild=p;break;
}
}
}
j++;
ch=str;
}
}
BTNode *FindNode(BTNode *b,elemtype x) /*返回data域为x的结点指针*/
{
BTNode *p;
if (b==NULL)
return NULL;
else if (b->data==x)
return b;
else
{
p=FindNode(b->lchild,x);
if (p!=NULL)
return p;
else
return FindNode(b->rchild,x);
}
}
BTNode *LchildNode(BTNode *p) /*返回*p结点的左孩子结点指针*/
{
return p->lchild;
}
BTNode *RchildNode(BTNode *p) /*返回*p结点的右孩子结点指针*/
{
return p->rchild;
}
int BTNodeDepth(BTNode *b) /*求二叉树b的深度*/
{
int lchilddep,rchilddep;
if (b==NULL)
return(0); /*空树的高度为0*/
else
{
lchilddep=BTNodeDepth(b->lchild); /*求左子树的高度为lchilddep*/
rchilddep=BTNodeDepth(b->rchild); /*求右子树的高度为rchilddep*/
return (lchilddep>rchilddep)? (lchilddep+1):(rchilddep+1);
}
}
int Nodes(BTNode *b) /*求二叉树b的结点个数*/
{
int num1,num2;
if (b==NULL)
return 0;
else if (b->lchild==NULL && b->rchild==NULL)
return 1;
else
{
num1=Nodes(b->lchild);
num2=Nodes(b->rchild);
return (num1+num2+1);
}
}
void DispBTNode(BTNode *b) /*以括号表示法输出二叉树*/
{
if (b!=NULL)
{
printf("%c",b->data);
if (b->lchild!=NULL || b->rchild!=NULL)
{
printf("(");
DispBTNode(b->lchild);
if (b->rchild!=NULL) printf(",");
DispBTNode(b->rchild);
printf(")");
}
}
}
int count(BTNode *b,int &i) /*求二叉树b的子叶个数*/
{
if(b)
{if(b->lchild==NULL&&b->rchild==NULL)
i++;
count(b->lchild,i);
count(b->rchild,i);
}
return i;
}
void preorder(BTNode *b)
{
if (b!=NULL)
{
printf("%c",b->data);
preorder(b->lchild);
preorder(b->rchild);
}
}
void inorder(BTNode *b)
{
if (b!=NULL)
{
inorder(b->lchild);
printf("%c",b->data);
inorder(b->rchild);
}
}
void postorder (BTNode *b)
{
if(b!=NULL)
{
postorder(b->lchild);
postorder(b->rchild);
printf("%c",b->data);
}
}
int main ()
{
char a,d,h;
int high,number,num,k=0,j;
BTNode *b,*q,*z,*x;
gets(a);
printf("你输入的二叉树是%s\n",a);
CreateBTNode(b,a);
printf("请输入你想查找的节点");
scanf("%C",&d);
q=FindNode(b,d);
printf("左孩子节点为");
z=LchildNode(q);
printf("%c\n",z->data);
printf("右孩子节点为");
x=RchildNode(q);
printf("%c\n",x->data);
high=BTNodeDepth(b);
printf("树的高度是%d\n",high);
number=Nodes(b);
printf("数的总结点数为%d\n",number);
j=count(b,k);
printf("子叶结点个数%d\n",j);
printf("输出的二叉树为");
DispBTNode(b);
printf("\n");
printf("先序输入");
preorder(b);
printf("\n");
printf("中序输入");
inorder(b);
printf("\n");
printf("后序输入");
postorder (b);
printf("\n");
return 0;
} 人造人 发表于 2018-5-10 14:54
应该是你的开发环境问题,把你的代码贴上来,我在这边试试
#include<stdio.h>
#include<malloc.h>
#defineMaxSize 50
typedef char elemtype;
typedef struct node
{ elemtype data; // 结点的值
struct node *lchild,*rchild; // 左右孩子指针
}BTNode;
void CreateBTNode(BTNode *&b,char *str) /*由str串创建二叉链*/
{
BTNode *St,*p=NULL;
int top=-1,k,j=0;
char ch;
b=NULL; /*建立的二叉树初始时为空*/
ch=str;
while (ch!='\0') /*str未扫描完时循环*/
{
switch(ch)
{
case '(':top++;St=p;k=1; break; /*为左结点*/
case ')':top--;break;
case ',':k=2; break; /*为右结点*/
default:p=(BTNode *)malloc(sizeof(BTNode));
p->data=ch;p->lchild=p->rchild=NULL;
if (b==NULL) /*p指向二叉树的根结点*/
b=p;
else /*已建立二叉树根结点*/
{
switch(k)
{
case 1:St->lchild=p;break;
case 2:St->rchild=p;break;
}
}
}
j++;
ch=str;
}
}
BTNode *FindNode(BTNode *b,elemtype x) /*返回data域为x的结点指针*/
{
BTNode *p;
if (b==NULL)
return NULL;
else if (b->data==x)
return b;
else
{
p=FindNode(b->lchild,x);
if (p!=NULL)
return p;
else
return FindNode(b->rchild,x);
}
}
BTNode *LchildNode(BTNode *p) /*返回*p结点的左孩子结点指针*/
{
return p->lchild;
}
BTNode *RchildNode(BTNode *p) /*返回*p结点的右孩子结点指针*/
{
return p->rchild;
}
int BTNodeDepth(BTNode *b) /*求二叉树b的深度*/
{
int lchilddep,rchilddep;
if (b==NULL)
return(0); /*空树的高度为0*/
else
{
lchilddep=BTNodeDepth(b->lchild); /*求左子树的高度为lchilddep*/
rchilddep=BTNodeDepth(b->rchild); /*求右子树的高度为rchilddep*/
return (lchilddep>rchilddep)? (lchilddep+1):(rchilddep+1);
}
}
int Nodes(BTNode *b) /*求二叉树b的结点个数*/
{
int num1,num2;
if (b==NULL)
return 0;
else if (b->lchild==NULL && b->rchild==NULL)
return 1;
else
{
num1=Nodes(b->lchild);
num2=Nodes(b->rchild);
return (num1+num2+1);
}
}
void DispBTNode(BTNode *b) /*以括号表示法输出二叉树*/
{
if (b!=NULL)
{
printf("%c",b->data);
if (b->lchild!=NULL || b->rchild!=NULL)
{
printf("(");
DispBTNode(b->lchild);
if (b->rchild!=NULL) printf(",");
DispBTNode(b->rchild);
printf(")");
}
}
}
int count(BTNode *b,int &i) /*求二叉树b的子叶个数*/
{
if(b)
{if(b->lchild==NULL&&b->rchild==NULL)
i++;
count(b->lchild,i);
count(b->rchild,i);
}
return i;
}
void preorder(BTNode *b)
{
if (b!=NULL)
{
printf("%c",b->data);
preorder(b->lchild);
preorder(b->rchild);
}
}
void inorder(BTNode *b)
{
if (b!=NULL)
{
inorder(b->lchild);
printf("%c",b->data);
inorder(b->rchild);
}
}
void postorder (BTNode *b)
{
if(b!=NULL)
{
postorder(b->lchild);
postorder(b->rchild);
printf("%c",b->data);
}
}
int main ()
{
char a,d,h;
int high,number,num,k=0,j;
BTNode *b,*q,*z,*x;
gets(a);
printf("你输入的二叉树是%s\n",a);
CreateBTNode(b,a);
printf("请输入你想查找的节点");
scanf("%C",&d);
q=FindNode(b,d);
printf("左孩子节点为");
z=LchildNode(q);
printf("%c\n",z->data);
printf("右孩子节点为");
x=RchildNode(q);
printf("%c\n",x->data);
high=BTNodeDepth(b);
printf("树的高度是%d\n",high);
number=Nodes(b);
printf("数的总结点数为%d\n",number);
j=count(b,k);
printf("子叶结点个数%d\n",j);
printf("输出的二叉树为");
DispBTNode(b);
printf("\n");
printf("先序输入");
preorder(b);
printf("\n");
printf("中序输入");
inorder(b);
printf("\n");
printf("后序输入");
postorder (b);
printf("\n");
return 0;
} 人造人 发表于 2018-5-10 14:54
应该是你的开发环境问题,把你的代码贴上来,我在这边试试
代码应该没问题。 诸位的爸爸 发表于 2018-5-10 17:47
代码应该没问题。
重新建立一个项目试试
我这边可以
试试这个
#include <stdio.h>
int main()
{
printf("你输入的二叉树是%s\n", "");
return 0;
}
人造人 发表于 2018-5-10 17:57
重新建立一个项目试试
我这边可以
没用,中文依旧无法正常输出,“请输入一句话”输出结果是:请入句 诸位的爸爸 发表于 2018-5-11 08:23
没用,中文依旧无法正常输出,“请输入一句话”输出结果是:请入句
重新安装一下IDE ? 人造人 发表于 2018-5-11 12:32
重新安装一下IDE ?
怎么装??有资源吗
诸位的爸爸 发表于 2018-5-11 17:34
怎么装??有资源吗
换用vs2017吧
https://msdn.itellyou.cn/
人造人 发表于 2018-5-11 17:39
换用vs2017吧
https://msdn.itellyou.cn/
还是不行 诸位的爸爸 发表于 2018-5-14 12:54
还是不行
?
页:
[1]