【蓝桥杯】模拟题 Python 大学A 组 试题G: 杨辉三角形

本文介绍了一道蓝桥杯模拟题,涉及杨辉三角形和数列。给定正整数N,任务是找到数列中第一次出现N的位置。通过分析二项式定理和杨辉三角的性质,降低时间复杂度,实现高效算法。
摘要由CSDN通过智能技术生成

【问题描述】

下面的图形是著名的杨辉三角形:
在这里插入图片描述
如果我们按从上到下、从左到右的顺序把所有数排成一列,可以得到如下数列:
1, 1, 1, 1, 2, 1, 1, 3, 3, 1, 1, 4, 6, 4, 1, …
给定一个正整数N,请你输出数列中第一次出现N 是在第几个数?

【输入格式】

输入一个整数N。

【输出格式】

输出一个整数代表答案。

【样例输入】

6

【样例输出】

13

【评测用例规模与约定】

对于20% 的评测用例,1 <N <10;
对于所有评测用例,1 <N <1000000000。

试题分析:

省流版本:
如果直接用暴力枚举的话,需要求出每一行的全部数字,然后判断每一行中是否存在该整数,思路可以,但是时间复杂度太大,只能拿30%。如果根据二项式定理,找出从哪一行开始只需要遍历前三个数,然后利用求和公式直接计算答案,就可以大大减少时间复杂度。

题目解析:
首先介绍一下杨辉三角的性质:

1、每个数等于它上方两个数的和。

2、左右对称(说明最先出现的数一定在左边)

3、第n行有n个数,前n行就有(n+1)*n/2个数

4、n+1行的数是(a+b)^n展开后各项的系数

所以,由性质4可得,第n行的m个元素为C(n-1,m-1),由于1 ≤ N ≤ 1000000000,每一行第四个数为N*(N-1)*(N-2)/6,粗略计算,当N>1900时,第四项就大于1000000000了,所以说,从第1901行开始,N若是第一次出现,只可能出现在第二第三项。

因此,在前1900层时,可以直接使用暴力枚举,在判断是否在该层,若不在前面1900层,先粗略估计N所在的层数(先计算在第三项时,因为若存在,就会先出现)int((N*2)**0.5),这时,就只需要判断三种情况:①N在该层;②N在下一层;③N在N+1层。

最后计算在第几个数上,分为三种情况

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值