您的位置:

c语言杨辉三角不能用数组做,c语言杨辉三角代码不用数组

本文目录一览:

这个用数组C语言打印杨辉三角,怎么改为不用数组?

可以不用二维数组,改用一维数组。

如果有改为不用数组,那就使用计算阶乘的方法,计算效率较低,而且容易“溢出”不能算得较多的行数。如果要改为能得到用数组同样的行数,则程序的编写就要用麻烦的算法。

c语言:不使用数组编写杨辉三角形10行的递归程序

//输出杨辉三角

# include stdio.h

void main()

{

int yang(int x, int y);

int i, j, k;

for(i = 1; i = 10; i++)//i控制行数

{

for(j = 0; j 10-i; j++)

printf(" ");

for(k = 1; k = i; k++)//y表示这一行中第几个数

printf("%4d", yang(i, k));

printf("\n");

}

}

int yang(int x, int y)

{

int z;

if(y == 1 || y == x)  z = 1;

else z = yang(x-1, y-1) + yang(x-1, y);

return z;

}

不知道能不能满足lz要求。

c语言编程打印杨辉数字金字塔不用数组

#includestdio.h

#define N 10

void main()

{

unsigned int i,j,k;

unsigned int b,c;

for(i=0;iN;i++)

{

for(j=N;ji;j--)

printf(" ");

for(j=0;j=i;j++)

{

b=c=1;

if(j=1)

{

for(k=i-j+1;k=i;k++)

b*=k;

for(k=1;k=j;k++)

c*=k;

}

printf("%4d",b/c);

}

printf("\n");

}

}

在打印杨辉三角时通常用到杨辉三角的两个性质。

第一个就是杨辉三角中除了最外层的数为1外,其余的数都是它肩上两个数之和。用数组输出杨辉三角就用这个性质。

第二个性质是杨辉三角的第n行恰好是C(n,0)~C(n,n)。这里的C表示组合。不用数组输出杨辉三角就用这个性质。

哪里不明白可以Hi我。

大学c语言循环章节问题。(不用数组) 编写程序,输出杨辉三角形

#include stdio.h

#define N 14

void main()

{

int i, j, k, n=0, a[N][N]; /*定义二维数组a[14][14]*/

while(n=0||n=13){ /*控制打印的行数不要太大,过大会造成显示不规范*/

printf("请输入要打印的行数:");

scanf("%d",n);

}

printf("%d行杨辉三角如下:\n",n);

for(i=1;i=n;i++)

a[i][1] = a[i][i] = 1; /*两边的数令它为1,因为现在循环从1开始,就认为a[i][1]为第一个数*/

for(i=3;i=n;i++)

for(j=2;j=i-1;j++)

a[i][j]=a[i-1][j-1]+a[i-1][j]; /*除两边的数外都等于上两顶数之和*/

for(i=1;i=n;i++){

for(k=1;k=n-i;k++)

printf(" "); /*这一行主要是在输出数之前打上空格占位,让输出的数更美观*/

for(j=1;j=i;j++) /*j=i的原因是不输出其它的数,只输出我们想要的数*/

printf("%6d",a[i][j]);

printf("\n"); /*当一行输出完以后换行继续下一行的输出*/

}

printf("\n");

}

拓展资料:

C语言是一门通用计算机编程语言,广泛应用于底层开发。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台。

二十世纪八十年代,为了避免各开发厂商用的C语言语法产生差异,由美国国家标准局为C语言制定了一套完整的美国国家标准语法,称为ANSI C,作为C语言最初的标准。