1234:2011——快速幂+高精除

2023-10-28 20:59
文章标签 快速 2011 1234 高精除

本文主要是介绍1234:2011——快速幂+高精除,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【题目描述】
已知长度最大为200位的正整数n,请求出2011^n的后四位。

【输入】
第一行为一个正整数k,代表有k组数据(k≤200),接下来的k行,每行都有一个正整数n,n的位数≤200。

【输出】
每一个n的结果为一个整数占一行,若不足4位,去除高位多余的0。

【输入样例】
3
5
28
792
【输出样例】
1051
81
5521

分析

解法一 快速幂+高精除

  1. 刚开始没看清题,以为n<=200,就直接for循环暴力求2011的n次幂,后来提交发现TLE,以为暴力for太慢了,然后用快速幂,发现WA了,后来知道n的位数是小于200,所以直接爆int、long long了;所以此处需要用到高精度运算,用数组去存储n的每一位;
  2. 这里我用了一个len表示n数组的有效长度,也可以用n[0]来存数组长度(n的有效值长度),在改变数组的函数中(change函数、divide函数中),改变完重新给n[0]赋值。
  3. 将原来快速幂的幂用数组表示,有这些操作:判断n是否为0,以及n/2,以及n的最后一位是否为1,用数组模拟即可;
  4. 高精度除一个小的数,还是比较简单的,没那么复杂;
    在这里插入图片描述
#include<bits/stdc++.h>using namespace std;int k, ans;
int len;//表示n数组的有效长度,也可以用a[0]来存数组长度,在改变数组的函数中(change函数、数组除以2的函数中),改变完重新给a[0]赋值
string s;
int n[205];//把n数组表示的数除2
void divide() {int x = 0;//表示上一位的余数for (int i = len - 1; i >= 0; i--) {x = x * 10 + n[i];n[i] = x / 2;x = x % 2;//当前的余数}//去除前导0,比如02352while (n[len - 1] == 0 && len > 1) {len--;}
}//指数为高精度数字的数组n的快速幂
int quickPower(int a) {int res = 1;int temp = a;while (len > 1 || (len == 1 && n[len - 1] != 0)) {//n不为0if (n[0] % 2) {res = res * temp % 10000;}//b = b >> 1;换为高精除divide();temp = temp * temp % 10000;}return res;
}//把s存在n数组中
void change(string s) {len = s.size();for (int i = 0; i < len; i++)n[i] = (s[len - i - 1] - '0');
}int main() {std::ios::sync_with_stdio(false);cin.tie(nullptr);cin >> k;while (k--) {memset(n, 0, sizeof n);cin >> s;//注意n是200位的数字,远大于long longchange(s);//超时,以为n是范围小于200的数/*for (int i = 1; i <= n; i++) {ans = ans * 2011 % 10000;}*/ans = quickPower(2011);cout << ans << endl;}return 0;
}

解法二 利用2011^500 % 10000=1

参考的:信息学奥赛一本通 1234:2011 | OpenJudge NOI 2.4 2991:2011

  1. 循环长度:假如求后k位值,如果n的循环长度是L,那么说明对于任意的正整数a,n ^ a = n ^ (a+L)的最后k位都相同。看a的几次方模10000的结果等于a,就能找出循环长度。
  2. 由于2011^500 % 10000=1,所以2011 ^ 1 = 2011 ^ 501(指的后4位的值相等) ,所以此题的循环长度为500;也就是 a ^ b % 10000 = a ^ (b+500) % 10000;
  3. 所以指数n只取三位即可求得结果,然后直接暴力for就能算,就不用上面的高精除+快速幂;
  4. 本题通过了一个f函数求得,2011 ^ 501 % 10000 = 2011 ^ 1 % 10000,故循环长度就是500;
#include<bits/stdc++.h>using namespace std;int k, ans;
string s;//看a的几次方模10000的结果等于a,来找循环长度
int f(int a) {int i = 1, temp = a;while (++i) {temp = temp * a % 10000;if (temp == a)break;}return i;
}int main() {std::ios::sync_with_stdio(false);cin.tie(nullptr);//找循环长度
//    int len = f(2011);
//    cout << len;      =>len=501cin >> k;while (k--) {cin >> s;int b = 0;//保留后三位指数即可if (s.size() >= 3) {//指数长度超过3位,取最后3位for (int i = s.size() - 3; i < s.size(); i++) {b = b * 10 + s[i] - '0';}} else {//不足3位,有几位取几位for (int i = 0; i < s.size(); i++)b = b * 10 + s[i] - '0';}b %= 500;//循环长度为500ans = 1;for (int i = 1; i <= b; i++) {ans = ans * 2011 % 10000;}cout << ans << endl;}return 0;
}

这篇关于1234:2011——快速幂+高精除的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/295928

相关文章

shell脚本快速检查192.168.1网段ip是否在用的方法

《shell脚本快速检查192.168.1网段ip是否在用的方法》该Shell脚本通过并发ping命令检查192.168.1网段中哪些IP地址正在使用,脚本定义了网络段、超时时间和并行扫描数量,并使用... 目录脚本:检查 192.168.1 网段 IP 是否在用脚本说明使用方法示例输出优化建议总结检查 1

Rust中的Option枚举快速入门教程

《Rust中的Option枚举快速入门教程》Rust中的Option枚举用于表示可能不存在的值,提供了多种方法来处理这些值,避免了空指针异常,文章介绍了Option的定义、常见方法、使用场景以及注意事... 目录引言Option介绍Option的常见方法Option使用场景场景一:函数返回可能不存在的值场景

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

hdu 4565 推倒公式+矩阵快速幂

题意 求下式的值: Sn=⌈ (a+b√)n⌉%m S_n = \lceil\ (a + \sqrt{b}) ^ n \rceil\% m 其中: 0<a,m<215 0< a, m < 2^{15} 0<b,n<231 0 < b, n < 2^{31} (a−1)2<b<a2 (a-1)^2< b < a^2 解析 令: An=(a+b√)n A_n = (a +

v0.dev快速开发

探索v0.dev:次世代开发者之利器 今之技艺日新月异,开发者之工具亦随之进步不辍。v0.dev者,新兴之开发者利器也,迅速引起众多开发者之瞩目。本文将引汝探究v0.dev之基本功能与优势,助汝速速上手,提升开发之效率。 何谓v0.dev? v0.dev者,现代化之开发者工具也,旨在简化并加速软件开发之过程。其集多种功能于一体,助开发者高效编写、测试及部署代码。无论汝为前端开发者、后端开发者

利用Django框架快速构建Web应用:从零到上线

随着互联网的发展,Web应用的需求日益增长,而Django作为一个高级的Python Web框架,以其强大的功能和灵活的架构,成为了众多开发者的选择。本文将指导你如何从零开始使用Django框架构建一个简单的Web应用,并将其部署到线上,让世界看到你的作品。 Django简介 Django是由Adrian Holovaty和Simon Willison于2005年开发的一个开源框架,旨在简

CentOs7上Mysql快速迁移脚本

因公司业务需要,对原来在/usr/local/mysql/data目录下的数据迁移到/data/local/mysql/mysqlData。 原因是系统盘太小,只有20G,几下就快满了。 参考过几篇文章,基于大神们的思路,我封装成了.sh脚本。 步骤如下: 1) 先修改好/etc/my.cnf,        ##[mysqld]       ##datadir=/data/loc

SAM2POINT:以zero-shot且快速的方式将任何 3D 视频分割为视频

摘要 我们介绍 SAM2POINT,这是一种采用 Segment Anything Model 2 (SAM 2) 进行零样本和快速 3D 分割的初步探索。 SAM2POINT 将任何 3D 数据解释为一系列多向视频,并利用 SAM 2 进行 3D 空间分割,无需进一步训练或 2D-3D 投影。 我们的框架支持各种提示类型,包括 3D 点、框和掩模,并且可以泛化到不同的场景,例如 3D 对象、室

UE5 半透明阴影 快速解决方案

Step 1: 打开该选项 Step 2: 将半透明材质给到模型后,设置光照的Shadow Resolution Scale,越大,阴影的效果越好

快速排序(java代码实现)

简介: 1.采用“分治”的思想,对于一组数据,选择一个基准元素,这里选择中间元素mid 2.通过第一轮扫描,比mid小的元素都在mid左边,比mid大的元素都在mid右边 3.然后使用递归排序这两部分,直到序列中所有数据均有序为止。 public class csdnTest {public static void main(String[] args){int[] arr = {3,