当前位置: 首页 > article >正文

蓝桥杯疑似例题解答方案(打印任意阶杨辉三角)

题目:输入n,打印n阶的杨辉三角


杨辉三角是一种特殊的由数字构成的三角形,边缘上的数字都是1,内部的数字则是左上角和右上角数字的加和。它本质上其实是二项展开的系数序列(我们通过这个性质可以给出一种与本篇文章的方法不同的解决方案,不过我们这次不讨论。)

事实上,在不适用二项展开序列的性质的前提下,单纯的计算杨辉三角的某个位置的数值已经过于复杂,因为这意味着你必须把以它为顶点的等腰倒三角的所有项都算出来以有利于你进行对它本身的运算,这给了我们很大的麻烦。

第二个难点在于,杨辉三角必须以特殊的方法进行打印,不然从终端(Terminal)上来看,就会从等腰三角形变成直角三角形,这个直角三角形看起来不是很美观,因此不合适。

下面我给出一种计算出并打印任意阶杨辉三角的解决方案,本方案基于加和定义给出。

前面几篇有关蓝桥杯例题的文章中我的代码都是一个int main解决一切的,有朋友批评我耦合度太高,事实上,因为我认为它们没有很大难度,因此没有必要进行低耦合的写法,一口气解决也就罢了。但是为了回应这种质疑声,我这次采取低耦合的方法写,将代码拆分出两个功能性函数funcSetOne()和funcSetOther()。

警告:由于十进制导致的问题,有些数字是一位的,有些是两位的,大一些的数字有四五位的,由于它们长度不同,因此打印杨辉三角的时候,很有可能会从某阶开始歪掉,这是正常情况,也是无可奈何的事情。

下面展示完整的代码:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
void funcSetOne(int arr[30][30],int a) {
	int u = 0; int t = 0;
	t = a;
	while (u < t) {
		arr[u][a] = 1;
		u++; a--;
	}
	u = 0; a = t;
	while (u < a) {
		arr[u][t] = 1;
		u++; t++;
	}
}
void funcSetOther(int arr[30][30], int a) {
	int u = 2; int t = 0;
	t = a;
	while (u < t) {
		arr[u][a] = arr[u - 1][a - 1] + arr[u - 1][a + 1];
		u++; a--;
	}
	u = 2; a = t;
	while (u < a) {
		arr[u][t] = arr[u - 1][t - 1] + arr[u - 1][t + 1];
		u++; t++;
	}
}
int main()
{
	int input = 0; int t = 0;
	int ctrl_1 = 0;
	int ctrl_2 = 0;
	int arr[30][30] = { 0 };
	scanf("%d", &input);
	ctrl_1 = input;
	funcSetOne(arr,ctrl_1);
	if (ctrl_1 > 2) {
		for (ctrl_2 = 2; ctrl_2 < input - 1; ctrl_2++) {
			funcSetOther(arr, ctrl_1+t);
			t+=2;
		}
	}
	int x = 0, y = 0;
	for (x = 0; x < input; x++) {
		for (y = 0; y < 2 * input + 1; y++) {
			if (arr[x][y] == 0) {
				printf(" ");
			}
			else {
				printf("%d", arr[x][y]);
			}
		}
		printf("\n");
	}
	return 0;
}


http://www.kler.cn/a/407969.html

相关文章:

  • JDBC 详解:从基础到高级完全指南
  • 私有化部署视频平台EasyCVR宇视设备视频平台如何构建视频联网平台及升级视频转码业务?
  • 物体网格弹性变形---Unity中实现
  • 图论最短路(floyed+ford)
  • 课程考核 三道模拟题
  • JDBC编程---Java
  • ubuntu 交叉编译arm架构的mysql
  • php常用伪协议整理
  • 从〇开始深度学习(0)——背景知识与环境配置
  • Spring框架深度剖析:特性、安全与优化
  • [代码随想录Day21打卡] 669. 修剪二叉搜索树 108.将有序数组转换为二叉搜索树 538.把二叉搜索树转换为累加树 总结篇
  • tomcat 后台部署 war 包 getshell
  • IntelliJ+SpringBoot项目实战(十)--常量类、自定义错误页、全局异常处理
  • 3D超声重建技术
  • C#里怎么样检测文件的属性?
  • 《Spring Boot:快速构建应用的利器》
  • 【青牛科技】 GC2803:白色家电与安防领域的卓越驱动芯片可替代ULN2803
  • stm32如何接收舵机的控制信号(而不是控制舵机)
  • 【AI】kimi深度版的荣誉之战(fail)
  • 软件测试面试之重要的名词解释
  • 大模型上层Agent系统思考
  • Perforce《2024游戏技术现状报告》Part3:生成式AI、版本控制、CI/CD等游戏技术的未来趋势与应用
  • FreeSWITCH 简单图形化界面34 - 网络环境安全的情况下,进行任意SIP注册
  • 案例研究|阿特斯的JumpServer分布式部署和多组织管理实践
  • 摄像机视频分析软件下载LiteAIServer视频智能分析平台玩手机打电话检测算法技术的实现
  • P2TR(Taproot 交易)和Musig2