[保研/考研机试] 杨辉三角形 西北工业大学复试上机题 C++实现

题目描述

Time Limit: 1000 ms

Memory Limit: 256 mb

输入n值,使用递归函数,求杨辉三角形中各个位置上的值。

输入描述:

复制代码
一个大于等于2的整型数n

输出描述:

复制代码
题目可能有多组不同的测试数据,对于每组输入数据,
按题目的要求输出相应输入n的杨辉三角形。

示例

输入:

cpp 复制代码
6

输出:

cpp 复制代码
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1

思路:

杨辉三角第一行和第二行的内容很明显,从第三行开始就很有规律了:每一行的第一个和最后一个元素都是1,从第二个到倒数第二个元素都是上一行的两个相邻元素的和。 这里可以简单的分为奇数行和偶数行,只需要**用两个一维数组就可以,保存相邻的两行元素,不断迭代更新它们的内容,并及时输出。**虽然用一个二维数组来保存每一行的数值会简单许多,但是题目输入的是一个大于等于2的整数n,当n很大时,如果用一个二维数组来保存每一行的数值会占用较大的空间。

注意:根据题目的示例输出,这里并不需要输出杨辉三角第一行的数值1。

源代码:

cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;

//习题8.1 杨辉三角形
int main()
{
	int n;
	vector<int> nums1 = { 1 };
	vector<int> nums2 = { 1,1 };
	while (cin >> n) {
		for (int i = 2; i <= n; i++) {
			if (i % 2 == 1) { //奇数行
				nums1.resize(1);
				for (int j = 1; j < i - 1; j++) {
					nums1.push_back(nums2[j - 1] + nums2[j]);
				}
				nums1.push_back(1);
				for (auto it : nums1) {
					cout << it << " ";
				}
				cout << endl;
			}
			else { //偶数行
				nums2.resize(1);
				for (int j = 1; j < i - 1; j++) {
					nums2.push_back(nums1[j - 1] + nums1[j]);
				}
				nums2.push_back(1);
				for (auto it : nums2) {
					cout << it << " ";
				}
				cout << endl;
			}
		}
	}
	
	return 0;
}

提交结果:

相关推荐
_F_y1 小时前
MySQL用C/C++连接
c语言·c++·mysql
兩尛2 小时前
c++知识点2
开发语言·c++
xiaoye-duck2 小时前
C++ string 底层原理深度解析 + 模拟实现(下)——面试 / 开发都适用
开发语言·c++·stl
Azure_withyou2 小时前
Visual Studio中try catch()还未执行,throw后便报错
c++·visual studio
琉染云月2 小时前
【C++入门练习软件推荐】Visual Studio下载与安装(以Visual Studio2026为例)
c++·visual studio
L_09074 小时前
【C++】高阶数据结构 -- 红黑树
数据结构·c++
A_nanda4 小时前
c# MOdbus rto读写串口,如何不相互影响
算法·c#·多线程
代码雕刻家6 小时前
2.4.蓝桥杯-分巧克力
算法·蓝桥杯
Ulyanov6 小时前
顶层设计——单脉冲雷达仿真器的灵魂蓝图
python·算法·pyside·仿真系统·单脉冲
智者知已应修善业7 小时前
【查找字符最大下标以*符号分割以**结束】2024-12-24
c语言·c++·经验分享·笔记·算法