[保研/考研机试] 杨辉三角形 西北工业大学复试上机题 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;
}

提交结果:

相关推荐
刀法如飞7 分钟前
Go数组去重的20种实现方式,AI时代解决问题的不同思路
后端·算法·go
汉克老师18 分钟前
GESP5级C++考试语法知识(贪心算法(一)课堂例题精讲)
c++·贪心算法·gesp5级·gesp五级·贪心规律
墨染千千秋28 分钟前
C++头文件的使用,和各个头文件与头文件用处
c++
呱呱巨基29 分钟前
Linux 基础IO
linux·c++·笔记·学习
旖-旎34 分钟前
深搜练习(N皇后)(10)
c++·算法·深度优先·力扣
苍煜1 小时前
二叉树、红黑树、B树、B+树通俗教学:各自适配场景+MySQL索引终极选型原因
数据结构·b树·mysql
Controller-Inversion1 小时前
322. 零钱兑换
算法
头发够用的程序员2 小时前
C++和Python面试经典算法汇总(一)
开发语言·c++·python·算法·容器·面试
淡海水2 小时前
【AI模型】模型量化技术详解
人工智能·算法·机器学习
炸膛坦客2 小时前
嵌入式 - 数据结构与算法:(1-1)数据结构 - 顺序表(Sequential List)
数据结构·算法·嵌入式