Juniorboy 发表于 2020-6-11 18:59:42

输出杨辉三角

本帖最后由 Juniorboy 于 2020-6-12 17:55 编辑

                                                                #include <stdio.h>
#include <stdlib.h>
int main(void)
{
        int** p = NULL;
        int a = 0, b = 0;
        printf("输入您要创建二维数组的行和列(a b) :");
        scanf_s("%d%d",&a,&b);
        p = (int**)malloc(sizeof(int*) * a);
        for (int i = 0; i < a; i++)
        {
                p = (int*)malloc(sizeof(int) * b);
        }
        //printf("——————————请输入二维数组的数据——————————");
        //printf("\n");
        //printf("请输入(默认数组初始化为0):");
        //printf("\n");
        //int c = 1 ;
        for (int i = 0; i < a; i++)
        {
                for (int j = 0; j < b; j++)
                {
                        int x = 0;
                        //scanf_s("%d", &x);
                        //p = x;       
                        p = 0;
                }
        }
                //printf("——————————数据录入完毕——————————");
                //printf("\n");
                //printf("数据如下:");
                //printf("\n");

                //for (int i = 0; i < a; i++)
                //{
                //        for (int j = 0; j < b; j++)
                //        {
                //               
                //                printf ("%6d ",p) ;
                //        }
                //        printf("\n");
                //}
                //printf("/*************************************************************************************************/");

                /*************************************************************************************************/

                printf("请输入您想要输出的杨辉三角的行数:");
                int s = 0;
                scanf_s("%d", &s);
                for (int i = 0; i < s; i++)
                        p = p = 1;

                for (int i = 2; i < s; i++)
                {
                        for (int k = 1; k < s; k++)
                        {
                                p = p + p;
                        }
                }

                for (int i = 0; i < s; i++)
                {
                        for ( intp = 0; p < 20 -i; p++)
                        {
                                printf("   ");
                        }
                        for (int j = 0; j < i + 1; j++)
                        {
                                printf("%6d", p);
                        }
                        printf("\n");
                }
                printf("\n");
                return 0;
}


我查了好几次也没找到问题所在,输出的结果是这样的,求解,谢谢啦

                                                                  1
                                                            1   1
                                                         1   2   1
                                                      1   3   3   1
                                                   1   4   6   4   1
                                                1   5    10    10   5   1
                                             1   6    15    20    15   6   1
                                          1   7    21    35    35    21   7   1
                                       1   8    28    56    70    56    28   8   1
                                    1   9    36    84   126   126    84    36   9   1
                                 1    10    45   120   210   252   210   120    45    10   1
                              1    11    55   165   330   462   462   330   165    55    11   1
                           1    12    66   220   495   792   924   792   495   220    66    12   1
                        1    13    78   286   7151287171617161287   715   286    78    13   1
                     1    14    91   3641001200230033432300320021001   364    91    14   1
                  1    15   105   45513653003500564356435500530031365   455   105    15   1
               1    16   120   560182043688008 11440 12870 11440800843681820   560   120    16   1
            1    17   136   68023806188 12376 19448 24310 24310 19448 1237661882380   680   136    17   1
         1    18   153   81630608568 18564 31824 43758 48620 43758 31824 1856485683060   816   153    18   1      1    19   171   9693876 11628 27132 50388 75582 92378 92378 75582 50388 27132 116283876   969   171    19   1

soupman 发表于 2020-6-12 00:09:42

你是格式问题还是啥,请把输入参数发出来

Juniorboy 发表于 2020-6-12 14:40:10

soupman 发表于 2020-6-12 00:09
你是格式问题还是啥,请把输入参数发出来

输入您要创建二维数组的行和列(a b) : 20 20
请输入您想要输出的杨辉三角的行数:20

Juniorboy 发表于 2020-6-12 14:59:52

soupman 发表于 2020-6-12 00:09
你是格式问题还是啥,请把输入参数发出来

1    19   171   9693876 11628 27132 50388 75582 92378 92378 75582 50388 27132 116283876   969   171    19   1
就是这行没有换行,本来要输出一个三角形的,格式问题

Juniorboy 发表于 2020-6-12 15:22:49

soupman 发表于 2020-6-12 00:09
你是格式问题还是啥,请把输入参数发出来

我刚才输出了一个21行的三角形,第21行正确,20行还是输出了错误的格式

永远的渣滓 发表于 2020-6-12 20:31:15

可以

405794672 发表于 2020-6-12 20:51:45

首先要先查出杨辉三角的特性。前些日子我找了经典例题100例。里面有这题,仔细研究了一下。因为我那时第一次听说杨辉三角。百度百科上面的介绍看得很晕,理解起来很绕。所幸我全弄懂了。上面的介绍真是坑。说了很多废话,用其中一个特性就OK了。选你觉得比较简单的。按照上面的计算方法进行设计是不会错的。
另外,楼主非要用malloc?我可不喜欢。不知道new可不可以。没办法,试验而已,不行就直接硬设,不让用户输入。

405794672 发表于 2020-6-12 21:07:11

似乎不可能啊。竟然没换行。这就尴尬了!不知道原因。改天我也去试主式看看我的20行会不会也是这样

Juniorboy 发表于 2020-6-12 21:15:10

405794672 发表于 2020-6-12 21:07
似乎不可能啊。竟然没换行。这就尴尬了!不知道原因。改天我也去试主式看看我的20行会不会也是这样

哈哈哈,就是出了错

人造人 发表于 2020-6-12 22:39:27

soupman 发表于 2020-6-12 23:14:45

你把cmd窗口调大点就好了


soupman 发表于 2020-6-12 23:17:02

这啥玩意,截图发不了,你把cmd窗口调大点就好了

Neverturnback 发表于 2020-6-13 00:46:33

①代码没问题的,主要是你的黑窗口显示不够的问题导致的。
②你可以把黑窗口最大化,就可以了。
③图片是直接复制你的代码的运行结果

405794672 发表于 2020-6-14 14:51:14

今天想起了那出,试了一下,21行都没有问题

Juniorboy 发表于 2020-6-14 15:18:19

405794672 发表于 2020-6-14 14:51
今天想起了那出,试了一下,21行都没有问题

明白了,那就是我的编译器的输出格式有问题
页: [1]
查看完整版本: 输出杨辉三角