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

【题目链接】

ybt 1615:【例 1】序列的第 k 个数

本题的 a 、 b 、 c a、b、c a、b、c,等差数列公差、等比数列的公比都为整数。

【题目考点】

1. 快速幂

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

2. 等差数列

相邻两项的差相等的数列为等差数列。

设第 i i i项为 a i a_i ai,公差为 d d d

等差数列的递推公式: a i = a i − 1 + d a_i = a_{i-1}+d ai=ai−1+d

等差数列的通项公式: a i = a 1 + ( i − 1 ) d a_i = a_1+(i-1)d ai=a1+(i−1)d

3. 等比数列

相邻两项的比值相等的数列为等比数列。

设第 i i i项为 a i a_i ai,公比为 q q q

等比数列的递推公式: a i = a i − 1 q a_i = a_{i-1}q ai=ai−1q

等比数列的通项公式: a i = a 1 q i − 1 a_i = a_1q^{i-1} ai=a1qi−1

【解题思路】

设 M = 200907 M=200907 M=200907

每组数据,输入了数列的前三项

先判断第二项减第一项的值,与第三项减第二项的值是否相等,即是否有 b − a = c − b b-a=c-b b−a=c−b

如果满足该情况,则该数列相邻两项的差相等,是等差数列。否则就是等比数列。

  • 如果该数列是等差数列,则公差为 b − a b-a b−a,使用通项公式求等差数列第 k k k项,再对 M M M取模: 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 M akmodM=(a1+(k−1)d)modM=(a+(k−1)(b−a))modM
  • 如果该数列是等比数列,则公比为 b a \frac{b}{a} ab,使用通项公式求等比数列第 k k k项,再对 M M M取模: 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 M akmodM=a1qk−1modM=a(ab)k−1modM=(amodM)((ab)k−1modM)modM

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

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

【题解代码】

解法1:快速幂
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int M = 200907;
LL fastPow(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;
	}
	return r;
}
int main()
{
	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/a 
			cout << a*fastPow(b/a, k-1, M)%M << endl;
	}
	return 0;
}
相关推荐
程序leo源11 小时前
C语言知识总结
c语言·开发语言·c++·经验分享·笔记·青少年编程·c#
沫璃染墨11 小时前
二叉搜索树完全指南:从核心原理到增删查改全实现
开发语言·c++
‎ദ്ദിᵔ.˛.ᵔ₎11 小时前
C++哈希表
数据结构·c++·散列表
yongui4783411 小时前
基于 GA 优化的 BP 神经网络算法分析与 MATLAB 实现
神经网络·算法·matlab
想学会c++12 小时前
单例模式笔记总结
c++·笔记·单例模式
阿旭超级学得完12 小时前
C++11(初始化)
java·开发语言·数据结构·c++·算法
黎阳之光12 小时前
黎阳之光:视频孪生硬核赋能,共启数字孪生水利监测新征程
大数据·人工智能·算法·安全·数字孪生
云淡风轻~窗明几净12 小时前
关于角谷猜想的五行小猜想
数据结构·算法
广州灵眸科技有限公司12 小时前
瑞芯微(EASY EAI)RV1126B openclaw部署接入飞书
linux·网络·人工智能·算法·yolo·飞书
工业机器人销售服务12 小时前
告别漫长停机:伯朗特机器人如何用“自动换模”重塑生产效率
大数据·人工智能·算法