鱼C论坛

 找回密码
 立即注册
查看: 3522|回复: 13

求大佬帮一下忙

[复制链接]
发表于 2018-5-10 01:11:21 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
英文和数字输出没问题,汉字输出就有问题,比如说,一句话,一个字输出了下一个字就不输出了。
1525882712(1).jpg
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-5-10 12:04:32 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-5-10 13:22:37 From FishC Mobile | 显示全部楼层
求大佬帮帮忙
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-5-10 14:54:52 | 显示全部楼层
应该是你的开发环境问题,把你的代码贴上来,我在这边试试
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-10 17:45:58 | 显示全部楼层
#include<stdio.h>
#include<malloc.h>
#define  MaxSize 50
typedef char elemtype;

typedef struct node
{         elemtype data; // 结点的值
    struct node *lchild,*rchild; // 左右孩子指针
}BTNode;

void CreateBTNode(BTNode *&b,char *str)                /*由str串创建二叉链*/
{
        BTNode *St[MaxSize],*p=NULL;
        int top=-1,k,j=0;
        char ch;
        b=NULL;                                /*建立的二叉树初始时为空*/
        ch=str[j];
        while (ch!='\0')        /*str未扫描完时循环*/
        {
                      switch(ch)
                {
                case '(':top++;St[top]=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[top]->lchild=p;break;
                                                case 2:St[top]->rchild=p;break;
                                                }
                                        }
                }
                j++;
                ch=str[j];
        }
}

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[20],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;
}
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-10 17:46:53 | 显示全部楼层
人造人 发表于 2018-5-10 14:54
应该是你的开发环境问题,把你的代码贴上来,我在这边试试
  1. #include<stdio.h>
  2. #include<malloc.h>
  3. #define  MaxSize 50
  4. typedef char elemtype;

  5. typedef struct node
  6. {         elemtype data; // 结点的值
  7.     struct node *lchild,*rchild; // 左右孩子指针
  8. }BTNode;

  9. void CreateBTNode(BTNode *&b,char *str)                /*由str串创建二叉链*/
  10. {
  11.         BTNode *St[MaxSize],*p=NULL;
  12.         int top=-1,k,j=0;
  13.         char ch;
  14.         b=NULL;                                /*建立的二叉树初始时为空*/
  15.         ch=str[j];
  16.         while (ch!='\0')        /*str未扫描完时循环*/
  17.         {
  18.                       switch(ch)
  19.                 {
  20.                 case '(':top++;St[top]=p;k=1; break;                /*为左结点*/
  21.                 case ')':top--;break;
  22.                 case ',':k=2; break;                              /*为右结点*/
  23.                 default:p=(BTNode *)malloc(sizeof(BTNode));
  24.                         p->data=ch;p->lchild=p->rchild=NULL;
  25.                                  if (b==NULL)                    /*p指向二叉树的根结点*/
  26.                                                 b=p;
  27.                                         else                                                          /*已建立二叉树根结点*/
  28.                                         {       
  29.                                                 switch(k)
  30.                                                 {
  31.                                                 case 1:St[top]->lchild=p;break;
  32.                                                 case 2:St[top]->rchild=p;break;
  33.                                                 }
  34.                                         }
  35.                 }
  36.                 j++;
  37.                 ch=str[j];
  38.         }
  39. }

  40. BTNode *FindNode(BTNode *b,elemtype x)        /*返回data域为x的结点指针*/
  41. {
  42.         BTNode *p;
  43.         if (b==NULL)
  44.              return NULL;
  45.         else if (b->data==x)
  46.              return b;
  47.         else
  48.         {       
  49.                 p=FindNode(b->lchild,x);
  50.                 if (p!=NULL)
  51.                         return p;
  52.                 else
  53.                         return FindNode(b->rchild,x);
  54.         }
  55. }


  56. BTNode *LchildNode(BTNode *p)        /*返回*p结点的左孩子结点指针*/
  57. {
  58.     return p->lchild;
  59. }

  60. BTNode *RchildNode(BTNode *p)        /*返回*p结点的右孩子结点指针*/
  61. {
  62.     return p->rchild;
  63. }


  64. int BTNodeDepth(BTNode *b)        /*求二叉树b的深度*/
  65. {
  66.            int lchilddep,rchilddep;
  67.            if (b==NULL)
  68.                 return(0);                                                         /*空树的高度为0*/
  69.            else
  70.         {       
  71.                 lchilddep=BTNodeDepth(b->lchild);        /*求左子树的高度为lchilddep*/
  72.                   rchilddep=BTNodeDepth(b->rchild);        /*求右子树的高度为rchilddep*/
  73.                 return (lchilddep>rchilddep)? (lchilddep+1):(rchilddep+1);
  74.            }
  75. }


  76. int Nodes(BTNode *b)        /*求二叉树b的结点个数*/
  77. {
  78.         int num1,num2;
  79.     if (b==NULL)
  80.                 return 0;
  81.     else if (b->lchild==NULL && b->rchild==NULL)
  82.                 return 1;
  83.     else
  84.     {
  85.         num1=Nodes(b->lchild);
  86.         num2=Nodes(b->rchild);
  87.         return (num1+num2+1);
  88.         }

  89. }




  90. void DispBTNode(BTNode *b)        /*以括号表示法输出二叉树*/
  91. {
  92.         if (b!=NULL)
  93.         {
  94.                 printf("%c",b->data);
  95.                 if (b->lchild!=NULL || b->rchild!=NULL)
  96.                 {
  97.                         printf("(");
  98.                         DispBTNode(b->lchild);
  99.                         if (b->rchild!=NULL) printf(",");
  100.                         DispBTNode(b->rchild);
  101.                         printf(")");
  102.                 }
  103.         }
  104. }

  105. int count(BTNode *b,int &i)        /*求二叉树b的子叶个数*/
  106. {
  107. if(b)       
  108. {  if(b->lchild==NULL&&b->rchild==NULL)       
  109.            i++;

  110.         count(b->lchild,i);
  111.             count(b->rchild,i);
  112. }               
  113.         return i;
  114. }

  115. void preorder(BTNode *b)
  116. {
  117.   if (b!=NULL)
  118.   {
  119.   printf("%c",b->data);
  120.   preorder(b->lchild);
  121.   preorder(b->rchild);
  122.   }
  123. }

  124. void inorder(BTNode *b)
  125. {
  126. if (b!=NULL)
  127. {
  128. inorder(b->lchild);
  129. printf("%c",b->data);
  130. inorder(b->rchild);
  131. }
  132. }

  133. void postorder (BTNode *b)
  134. {
  135.   if(b!=NULL)
  136.   {
  137.   postorder(b->lchild);
  138.   postorder(b->rchild);
  139.   printf("%c",b->data);
  140.   }
  141. }


  142. int main ()
  143. {
  144.    char a[20],d,h;
  145.    int high,number,num,k=0,j;
  146.    BTNode *b,*q,*z,*x;
  147.    gets(a);
  148.    printf("你输入的二叉树是%s\n",a);
  149.   CreateBTNode(b,a);
  150.   printf("请输入你想查找的节点");
  151.   scanf("%C",&d);
  152.   q=FindNode(b,d);
  153.   printf("左孩子节点为");
  154.    z=LchildNode(q);
  155.   printf("%c\n",z->data);
  156.     printf("右孩子节点为");
  157.    x=RchildNode(q);
  158.   printf("%c\n",x->data);
  159.   high=BTNodeDepth(b);
  160.   printf("树的高度是%d\n",high);
  161.   number=Nodes(b);
  162.   printf("数的总结点数为%d\n",number);
  163.      j=count(b,k);
  164.   printf("子叶结点个数%d\n",j);
  165.   printf("输出的二叉树为");
  166.   DispBTNode(b);
  167.   printf("\n");
  168. printf("先序输入");
  169.   preorder(b);
  170.   printf("\n");
  171. printf("中序输入");
  172. inorder(b);
  173. printf("\n");
  174. printf("后序输入");
  175. postorder (b);
  176. printf("\n");
  177.    return 0;
  178. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-10 17:47:40 | 显示全部楼层
人造人 发表于 2018-5-10 14:54
应该是你的开发环境问题,把你的代码贴上来,我在这边试试

代码应该没问题。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-5-10 17:57:35 | 显示全部楼层

重新建立一个项目试试
我这边可以

试试这个
  1. #include <stdio.h>

  2. int main()
  3. {
  4.         printf("你输入的二叉树是%s\n", "");

  5.         return 0;
  6. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-11 08:23:43 From FishC Mobile | 显示全部楼层
人造人 发表于 2018-5-10 17:57
重新建立一个项目试试
我这边可以


没用,中文依旧无法正常输出,“请输入一句话”输出结果是:请入句
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-5-11 12:32:34 | 显示全部楼层
诸位的爸爸 发表于 2018-5-11 08:23
没用,中文依旧无法正常输出,“请输入一句话”输出结果是:请入句

重新安装一下IDE ?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-11 17:34:34 | 显示全部楼层
人造人 发表于 2018-5-11 12:32
重新安装一下IDE ?

怎么装??有资源吗
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-5-11 17:39:03 | 显示全部楼层
诸位的爸爸 发表于 2018-5-11 17:34
怎么装??有资源吗

换用vs2017吧
https://msdn.itellyou.cn/
无标题.png
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-14 12:54:26 | 显示全部楼层
人造人 发表于 2018-5-11 17:39
换用vs2017吧
https://msdn.itellyou.cn/

还是不行
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-5-14 13:17:55 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-9 12:47

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表