C++信息学奥赛练习题-杨辉三角

杨辉三角形

时间限制: 1000 ms 内存限制: 65536 KB

提交数:71618 通过数: 47548

【题目描述】

例5.11 打印杨辉三角形的前n(2≤n≤20)行。杨辉三角形如下图:

当n=5时

复制代码
        1
      1   1
    1   2   1
  1   3   3   1
1   4   6   4   1

输出:

复制代码
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1

【输入】

输入行数n。

【输出】

输出如题述三角形。n行,每行各数之间用一个空格隔开。

【输入样例】

复制代码
5

【输出样例】

复制代码
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1

这是一个典型双循环与二维数组结合的问题。

|-------------------|-------------------|--------------------|--------------------|-------------------|-------------------|
| 1 a11 | | | | | |
| 1 a21 | 1 a22 | | | | |
| 1 a31 | 2 a32 | 1 a33 | | | |
| 1 a41 | 3 a42 | 3 a43 | 1 a44 | | |
| 1 a51 | 4 a52 | 6 a53 | 4 a54 | 1 a55 | |
| 1 a61 | 5 a62 | 10 a63 | 10 a64 | 5 a65 | 1 a66 |

答案代码如下

cpp 复制代码
#include<iostream>
using namespace std;
int main()
{
	int a[100][100],i,j,n;
	cin>>n;
	for(i=1;i<=n;i++)
	{
		for(j=1;j<=i;j++)
		{
			if(j==1||j==i) a[i][j]=1;
			else if(i>3&&j!=1||j!=i) a[i][j]=a[i-1][j-1]+a[i-1][j];
		}
	}
	for(i=1;i<=n;i++)
		{
			for(j=1;j<=i;j++)
			{
				cout<<a[i][j]<<" ";
			}
			cout<<endl;
		}
} 
相关推荐
一拳一个呆瓜2 小时前
【STL】_SCL_SECURE_NO_WARNINGS
c++·stl
小小编程路2 小时前
C++ 异常 完整讲解
开发语言·c++
一只齐刘海的猫4 小时前
【Leetcode】找到字符串中所有字母异位词
算法·leetcode·职场和发展
海清河晏1115 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
Frank学习路上5 小时前
【C++】面试:关键字与语法特性
c++·面试
liulilittle5 小时前
固定数组时间轮的槽过载优化:桶链表与批次执行
网络·数据结构·链表
IronMurphy6 小时前
【算法五十七】146. LRU 缓存
算法·缓存
Irissgwe6 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列
两片空白6 小时前
数据容器集合set/frozenset
数据结构