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

提交结果:

相关推荐
zl_dfq11 小时前
基于哈夫曼树的数据压缩算法
算法
多喝开水少熬夜11 小时前
算法-哈希表和相关练习-java
java·算法·散列表
xiaoye-duck11 小时前
数据结构之二叉树-堆
数据结构
@syh.11 小时前
【C++】map和set
开发语言·c++
余衫马11 小时前
聚类算法入门:像魔法一样把数据自动归类
人工智能·算法·机器学习·聚类
拾光Ծ11 小时前
C++11实用的“新特性”:列表初始化+右值引用与偷懒艺术——移动语义
开发语言·c++
CAU界编程小白11 小时前
数据结构系列之快速排序
数据结构·c++·算法
qwepoilkjasd11 小时前
C++ 虚函数与多态详解
c++
卡提西亚11 小时前
一本通网站1130:找第一个只出现一次的字符
数据结构·c++·笔记·算法·一本通
lkbhua莱克瓦2411 小时前
Java基础——集合进阶用到的数据结构知识点3
java·数据结构·github·平衡二叉树·avl