怎么斜着找?
因为在内斜行中元素总是较先出现的,所以我们要从内斜行开始从内往外开始找,找到第0行全是1的最外层为止。内到什么程度才行?内到第16行。我们知道在中心对称轴的元素是每一斜行中最小的,它的特点是 C( k, 2k ) 。
如果该斜行最小元素都已经超出10的9次方那么剩下的元素都是大于10的9次方的,也就是说这一斜行是没有意义的,不用考虑。经计算,只有16斜行以内的数才符合条件。
我们已经确定了起始元素,根据杨辉三角的渐增性,越往下元素值越大,说明就是有序的,可以使用二分查找提高查找效率。这里有二分查找和排序的模板,大家可以参考下我的这篇文章。
确定了查找的起点位置后就要确定查找的终点位置。我们以目标值作为我们的组合数下限。回到分析中的第三小点:组合数下限表示元素所在横行数-1,那么如果以目标值作为终点位置的组合数下限已经是非常大了,就算找不到也有第1斜行(全为1的是第0斜行)的公差为1的等差数列守着,所以一定能找到。
因为相同斜行的组合数上限不变,我们不断更换组合数下限的值,直到最后找到目标值即可。找到目标值后,根据此时的组合数上下限,结合杨辉三角组合数性质即可求出元素所在位置。以20: C( 6, 3 )为例,它是,第7行第4个元素。前面6行是个公差为1的等差数列,根据求和公式即可求出6行共有几个元素,最后再加4即为20所在位置。
精度问题: 因为最后输出的是整数,所以最后要使用int将计算结果中小数点后面的数去除。假设一个元素在几十万横行后面找到,那么求他的位置时它的前N项和是非常大的,但他所在的列数可能非常小,如果将他们相加后再转化为整型的话会造成数据丢失,导致与实际结果不符。这样放在蓝桥杯上的话只能够拿八十分。辛辛苦苦做出来的题却因为精度问题不能拿满分,属实可惜。这个问题我也想了好久没找到问题根源,最后看到一篇文章点醒了我,感谢 @Py小郑 。
=================================================================
求组合数
def C(a, b): # a为上限, b为下限
res = 1
for i in range(a):
res *= b / a
当结果大于目标值时无需继续运算,提高效率
if res > target:
return res
b -= 1
a -= 1
return res
二分查找目标元素
def search(k):
起始下限,也就是对称轴位置的元素
low = 2 * k
终点下限
high = target
可能出现high 小于 low 的情况,比如目标值很小,但行数还在十多行的时候。
这时候直接判断该斜行第一个元素也就是对称轴位置的元素的值是否是目标值即可。
if high <= low and C(k, low) != target:
return False
while low <= high:
mid = low + (high - low) // 2
val = C(k, mid)
if val > target:
high = mid - 1
elif val < target:
low = mid + 1
else:
根据等差数列前N项和公式求出前面有多少个元素,然后再加上他所在的列数
print(int(mid * (mid + 1) / 2) + k + 1)
return True
return False
target = int(input())
range第二个参数必须是-1,因为第0斜行才有1。
最后
Python崛起并且风靡,因为优点多、应用领域广、被大牛们认可。学习 Python 门槛很低,但它的晋级路线很多,通过它你能进入机器学习、数据挖掘、大数据,CS等更加高级的领域。Python可以做网络应用,可以做科学计算,数据分析,可以做网络爬虫,可以做机器学习、自然语言处理、可以写游戏、可以做桌面应用…Python可以做的很多,你需要学好基础,再选择明确的方向。这里给大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!
👉Python所有方向的学习路线👈
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
👉Python必备开发工具👈
工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。
👉Python全套学习视频👈
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。
👉实战案例👈
学python就与学数学一样,是不能只看书不做题的,直接看步骤和答案会让人误以为自己全都掌握了,但是碰到生题的时候还是会一筹莫展。
因此在学习python的过程中一定要记得多动手写代码,教程只需要看一两遍即可。
👉大厂面试真题👈
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Python爬虫全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:python)
起的朋友,同时减轻大家的负担。**
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:python)
[外链图片转存中…(img-8f8ufwnb-1711102204195)]