C/C++蓝桥杯之杨辉三角

问题描述:下面是著名的杨辉三角

1

1 1

1 2 1

1 3 3 1

1 4 6 4 1

1 5 10 10 5 1

... ... ...

如果按从上到下,从左到右的顺序把所有数排成一列,则可以得到如下数列:

1,1,1,1,2,1,1,3,3,1,1,4,6,4,1,...

给定一个正整数N,请你输出数列中N第一次出现是在第几个位置?

分析:本题主要考察杨辉三角的相关知识,通过观察可以得出杨辉三角的基本性质,每个数均等于它上方两数之和。

可以采用递推的方式从上到下计算出杨辉三角中每个元素的数值,边计算边比较。

首先看一个杨辉三角的打印C程序(我以前写的)

cpp 复制代码
#include<stdio.h>
#include<stdlib.h>
#define N 11//表示要打印的行数
int main()
{
	int i = 0;
	int j = 0;
	int tge[N][N];
	for (i = 0; i < N; i++)//先打印每一行的第一个和最后一个;
	{
		tge[i][0] = 1;
		tge[i][i] = 1;
	}
	for (i = 2; i < N; i++)//打印中间部分
	{
		for (int j = 1; j < i; j++)
		{
			tge[i][j] = tge[i - 1][j - 1] + tge[i - 1][j];
		}
	}
	for (i = 0; i < N; i++)
	{
		for (j = 0; j < 2 * (N - i); j++)
		{
			printf(" ");
		}
		for (j = 0; j <= i; j++)
		{
			printf("%4d", tge[i][j]);
		}
		printf("\n");
	}
	return 0;
}

C程序:

cpp 复制代码
#include<stdio.h>
#define M 20000//这里可以改变范围大小,有时题目中会给出要求
int a[M][M];//用数列来存放
int main()
{
	a[1][1] = 1;
	int num = 1;//数的总量一开始为1
	int N;
	printf("请输入要查询的数:");
	scanf("%ld", &N);//N代表要查找的数
	for (int i = 2; i < M; i++)
	{
		for (int j = 1; j <= i; j++)
		{
			a[i][j] = a[i - 1][j - 1] + a[i - 1][j];//每个数等于上方两数之和
			num++;//每算出一个数,数的总数量就加1

			if (a[i][j] == N)
			{
				printf("这个数的位置在第%d个", num);
				return 0;
			}
		}
	}
}

C++程序:

cpp 复制代码
//二分查找的方法
#include<iostream>
using namespace std;
int n;
int combi(int a,int b)
{
	int res=1;
	for(int i=a,j=1;j<=b;i--,j++)
	{
		res=res*i/j;
		if(res>n)
		{
			return res;
		}
	}
	return res;
}

bool check(int k)
{
	int l=k*2;
	int r=n;
	while(l<r)
	{
		int mid=(l+r)/2;
		if(combi(mid,k)>=n)
		{
			r=mid;
		}
		else
		{
			l=mid+1;
		}
	}
	if(combi(r,k)!=n)
	{
		return false;
	}
	cout<<r*(r+1)/2+k+1;
	return true;
}
int main()
{
	cout<<"请输入你要查找的数:";
	cin>>n;
	for(int k=16;k>=1;k--)
	{
		if(check(k))
			break;
	}
	return 0;
}

以上提供了两种方法,可供大家自由选择!

相关推荐
艾莉丝努力练剑25 分钟前
【LeetCode&数据结构】单链表的应用——反转链表问题、链表的中间节点问题详解
c语言·开发语言·数据结构·学习·算法·leetcode·链表
还债大湿兄2 小时前
《C++内存泄漏8大战场:Qt/MFC实战详解 + 面试高频陷阱破解》
c++·qt·mfc
珊瑚里的鱼5 小时前
LeetCode 692题解 | 前K个高频单词
开发语言·c++·算法·leetcode·职场和发展·学习方法
AI+程序员在路上5 小时前
QTextCodec的功能及其在Qt5及Qt6中的演变
开发语言·c++·qt
Risehuxyc6 小时前
C++卸载了会影响电脑正常使用吗?解析C++运行库的作用与卸载后果
开发语言·c++
不知道叫什么呀6 小时前
【C】vector和array的区别
java·c语言·开发语言·aigc
秋说6 小时前
【PTA数据结构 | C语言版】顺序队列的3个操作
c语言·数据结构·算法
景彡先生8 小时前
C++编译期计算:常量表达式(constexpr)全解析
服务器·c++
秋说9 小时前
【PTA数据结构 | C语言版】字符串插入操作(不限长)
c语言·数据结构·算法
tan77º9 小时前
【Linux网络编程】应用层自定义协议与序列化
linux·运维·服务器·网络·c++·tcp/ip