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

信息学奥赛一本通 1615:【例 1】序列的第 k 个数

【题目链接】

ybt 1615:【例 1】序列的第 k 个数
本题的a 、 b 、 c a、b、cabc,等差数列公差、等比数列的公比都为整数。

【题目考点】

1. 快速幂

相关知识见:洛谷 P1226 【模板】快速幂

2. 等差数列

相邻两项的差相等的数列为等差数列。
设第i ii项为a i a_iai,公差为d dd
等差数列的递推公式:a i = a i − 1 + d a_i = a_{i-1}+dai=ai1+d
等差数列的通项公式:a i = a 1 + ( i − 1 ) d a_i = a_1+(i-1)dai=a1+(i1)d

3. 等比数列

相邻两项的比值相等的数列为等比数列。
设第i ii项为a i a_iai,公比为q qq
等比数列的递推公式:a i = a i − 1 q a_i = a_{i-1}qai=ai1q
等比数列的通项公式:a i = a 1 q i − 1 a_i = a_1q^{i-1}ai=a1qi1

【解题思路】

M = 200907 M=200907M=200907
每组数据,输入了数列的前三项
先判断第二项减第一项的值,与第三项减第二项的值是否相等,即是否有b − a = c − b b-a=c-bba=cb
如果满足该情况,则该数列相邻两项的差相等,是等差数列。否则就是等比数列。

  • 如果该数列是等差数列,则公差为b − a b-aba,使用通项公式求等差数列第k kk项,再对M MM取模:a k m o d M = ( a 1 + ( k − 1 ) d ) m o d M = ( a + ( k − 1 ) ( b − a ) ) m o d M a_k\bmod M=(a_1+(k-1)d)\bmod M=(a+(k-1)(b-a))\bmod MakmodM=(a1+(k1)d)modM=(a+(k1)(ba))modM
  • 如果该数列是等比数列,则公比为b a \frac{b}{a}ab,使用通项公式求等比数列第k kk项,再对M MM取模:a k m o d M = a 1 q k − 1 m o d M = a ( b a ) k − 1 m o d M = ( a m o d M ) ( ( b a ) k − 1 m o d M ) m o d M a_k\bmod M=a_1q^{k-1}\bmod M=a(\frac{b}{a})^{k-1}\bmod M=(a\bmod M)((\frac{b}{a})^{k-1}\bmod M)\bmod MakmodM=a1qk1modM=a(ab)k1modM=(amodM)((ab)k1modM)modM

( b a ) k − 1 m o d M (\frac{b}{a})^{k-1}\bmod M(ab)k1modM需要用到快速幂取模算法。

本题无法使用递推公式求等差或等比数列第k kk项,因为k kk最大会达到1 0 9 10^9109,而递推求等差或等比数列第k kk项的时间复杂度是O ( n ) O(n)O(n)的,写代码运行会超时)

【题解代码】

解法1:快速幂
#include<bits/stdc++.h>usingnamespacestd;typedeflonglongLL;constintM=200907;LLfastPow(LL a,LL b,LL m){LL r=1;while(b>0){if(b%2==1)r=r*a%m;a=a*a%m;b/=2;}returnr;}intmain(){LL t,a,b,c,k;cin>>t;while(t--){cin>>a>>b>>c>>k;if(c-b==b-a)cout<<(a+(k-1)*(b-a))%M<<endl;else//c/b == b/acout<<a*fastPow(b/a,k-1,M)%M<<endl;}return0;}
http://www.cnnetsun.cn/news/175858.html

相关文章:

  • Excalidraw构建RFM模型:客户价值分层可视化
  • Vue.js入门指南:从核心特性到实战体验
  • Excalidraw绘制商业模式创新:价值主张重构
  • Excalidraw呈现智能合约流程:DApp交互路径
  • 58、高效管理联系人与日历:Windows Live 实用指南
  • 64、电脑使用安全与磁盘管理全攻略
  • 67、Windows 7磁盘管理与日常维护指南
  • 2025-12-22 全国各地响应最快的 BT Tracker 服务器(移动版)
  • Excalidraw呈现医疗信息系统:HIS/PACS集成视图
  • 15、深入探索Windows 7维护与故障排除
  • 【毕业设计】CBA球员数据可视化分析系统的设计与实现(系统配套论纹+答辩PPT)
  • Excalidraw实现KANO模型:需求优先级排序
  • 基于Java+大数据+SSMB站数据分析可视化系统(源码+LW+调试文档+讲解等)/B站数据可视化/B站数据分析/B站分析系统/数据可视化系统/数据分析系统/B站数据平台/B站可视化工具
  • 基于Python+大数据+SSMCBA球员数据可视化分析系统(源码+LW+调试文档+讲解等)/CBA球员数据展示系统/CBA球员数据统计系统/CBA球员数据分析平台/篮球数据可视化分析系统
  • Excalidraw导出PDF注意事项:格式保持完整
  • 【C++】优选算法必修篇之双指针实战:移动零 复写零
  • 【C++】继承深度解析:继承方式和菱形虚拟继承的详解
  • Excalidraw背景设置:更换画布颜色或图片
  • Excalidraw深度测评:为什么它成技术团队首选白板工具?
  • 笨人小白的温故知新——排序(3)
  • 基于python的RSA加密算法软件的研究设计(源码+文档)
  • Excalidraw界面原型设计:产品经理快速出稿方案
  • Excalidraw价值流图:精益生产流程优化
  • 嵌入式多线程从“能跑“到“稳定“的关键一步!
  • 【空间辨识】一致模态指标与模态参与因子的随机子空间辨识研究(Matlab代码实现)
  • 基于Java+SSM+SSM线上管理系统(源码+LW+调试文档+讲解等)/线上管理平台/在线管理系统/线上管理软件/网络管理系统/线上办公系统
  • 分层模糊系统:梯度下降与递推最小二乘法联合辨识研究(Matlab代码实现)
  • 人机差异的核心
  • Excalidraw暗黑模式设置:夜间使用的护眼方案
  • 精品UI知识付费系统源码 响应式视频教程知识付费软件下载网站模板