欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

C语言打印输出杨辉三角

时间:2021-06-10 08:24:22|栏目:C代码|点击:

杨辉三角,是二项式系数在三角形中的一种几何排列。

如下图所示:

规律:

1.每行端点与结尾的数为1.
2.每个数等于它上方两数之和。
2.每行数字左右对称,由1开始逐渐变大。
3.第n行的数字有n项。
4.每个数字等于上一行的左右两个数字之和。可用此性质写出整个杨辉三角。即第i+1行的第j个数等于第i行的第j-1个数和第j个数之和,这也是组合数的性质之一。即C(i+1,j)=C(i,j-1)+C(i,j)。

5.第 i 行第 j 个数可表示为:

例:

可以表示为: 7 的阶乘除以(7-3)的阶乘,再除以3的阶乘 即: ( 7! / (7-3)! )/ 3!
以下是笔者所写的代码:(使用了上述规律5)

/* 在屏幕上打印杨辉三角。
  by 向前
*/
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>

//该函数功能是求传入参数的阶乘
int Factorial(int num){
 if (num == 0){
 return 1;
 } else{
 int tmp = num;
 for (int i = 1; i < num; ++i){
  tmp = tmp*i;
 }
 return tmp;
 }
}
//杨辉三角第 i 行,第 j 个数的值为 C(j-1,i-1) 
int Num(int i, int j){
 int n = 0;
 n = Factorial(i - 1) / Factorial(i - j)/Factorial(j-1);
 return n;
}

int main(){
 int h = 0;
 printf("输入需要打印的行数\n");
 scanf("%d", &h); //  可以打印任意行数的杨辉三角
 if (h<1){
 printf("非法输入!请重新输入\n");
 } else{
 int s = h - 1;
 for (int i = 1; i <= h; ++i){
  for (s = h - i; s > 0; --s){  // 该循环是按照规律将空格输出,使之输出为一个三角形
  printf(" ");
  }
  for (int j = 1; j <= i; ++j){
  printf(" %d ", Num(i, j));
  }
  printf("\n\n"); // 每行输出结束后换行
 }
 }
 system("pause");
 return 0;
}

编译环境: Visual Studio 2013
运行效果如下:

上一篇:OpenCV获取视频的每一帧并保存为.jpg图片

栏    目:C代码

下一篇:C/C++ break和continue区别及使用方法

本文标题:C语言打印输出杨辉三角

本文地址:http://www.codeinn.net/misctech/139160.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有