c++,不知道哪里错了求解!!!

#include<bits/stdc++.h>
#define Maxsize 60
using namespace std;
struct node{
    char date[Maxsize];
    struct node *lchild;
    struct node *rchild;
};
node *CreateBT(char *pre,char*in,int n){
   node *b;
   char *p;
   int k;
   if(n<=0)return NULL;
   b=(node*)malloc(sizeof(node));
    b->date = * pre;
   for(p=in;p<in+n;p++)
       if(*p==*pre)
       break;
       k=p-in;
       b->lchild =CreateBT(pre+1,in,k);
       b->rchild =CreateBT(pre+k+1,p+1,n-k-1);
       return b;
}
int BTheight(node * b){
    int lchildh,rchildh;
    if(b==NULL) return (0);
    else{
        lchildh=BTheight(b->lchild );
        rchildh=BTheight(b->rchild );
        return (lchildh>rchildh)?(lchildh+1):(rchildh+1);
    }
    
}

int main () {
    node b;
    int m;
     cin>>m;
    getchar();
    for(int i=0;i<m;i++){
            int j;
            cin>>j;
            char a[Maxsize];
            char c[Maxsize];
            cin.getline(a,Maxsize);
            cin.getline(c,Maxsize);
            CreateBT(a,c,j);
             cout<<BTheight(&b)<<endl;
    }
    
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 您好,关于您的问题,我可以为您提供一个C语言的代码示例来计算阶乘。阶乘是指一个正整数n的阶乘,表示为n!,它等于n*(n-1)*(n-2)*...*2*1。当n为0时,定义其阶乘为1。以下是一个用C语言编写的求解阶乘的程序: ``` #include <stdio.h> int main() { int i, m, result = 1; printf("请输入一个整数m: "); scanf("%d", &m); for(i = 1; i <= m; i++) { result *= i; } printf("%d的阶乘是%d\n", m, result); return 0; } ``` 该程序中,使用了for循环和累乘运算符来计算阶乘。程序首先提示用户输入一个整数m,然后使用for循环计算m的阶乘,并将结果打印出来。当m等于0时,结果将为1。希望这个程序可以帮助您解决问题。 ### 回答2: 如果使用 C 语言来求 0! 到 m! 的结果,可以使用循环结构和阶乘的递归定义。 首先,阶乘的定义如下: 当 n = 0 时,0! = 1。 当 n > 0 时,n! = n * (n - 1)! 接下来,我们可以使用循环结构来求解 0! 到 m! 的结果。具体代码如下: ```c #include <stdio.h> // 计算阶乘的函数 int factorial(int n) { int result = 1; for (int i = 1; i <= n; i++) { result *= i; } return result; } int main() { int m; printf("请输入一个整数 m:"); scanf("%d", &m); for (int i = 0; i <= m; i++) { printf("%d! = %d\n", i, factorial(i)); } return 0; } ``` 在上述代码中,我们定义了一个函数 `factorial`,用于计算给定整数 n 的阶乘。然后在 `main` 函数中,我们首先读取一个整数 m,然后使用循环结构打印出 0! 到 m! 的结果。 举个例子,如果输入 m = 5,运行程序后输出如下: ``` 0! = 1 1! = 1 2! = 2 3! = 6 4! = 24 5! = 120 ``` 上述代码可以求解 0! 到任意整数 m 的阶乘结果。 ### 回答3: 首先,需要说明的是阶乘(factorial)是指将一个非负整数 n 及小于等于 n 的所有正整数相乘的结果,用 n! 来表示。如果 n=0,那么根据阶乘的定义,0! 的结果就是 1。 因此,当求解 0! 时,结果即为 1。 同样,当求解 1! 时,结果也是 1,因为 1 的阶乘就是 1*1 = 1。 接着,当求解 2! 时,结果为 2,因为 2 的阶乘就是 1*2 = 2。 以此类推,当求解 m! 时,结果为将 m 乘以小于等于 m 的所有正整数的乘积。例如,当 m=3 时,结果为 3 的阶乘,即 1*2*3 = 6。 综上所述,当求解 0! 1! … m! 时,依次的结果即为 1、1、2、3、4…… m。 需要注意的是,当输入的 m 小于 0 时,没有阶乘的定义,因此没有意义。此外,由于阶乘的计算结果很快增大,当 m 的值较大时,结果可能会出现整数溢出的情况,所以需要在编程中考虑合理的数据范围和处理方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值