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

相关文章

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

MybatisX快速生成增删改查的方法示例

《MybatisX快速生成增删改查的方法示例》MybatisX是基于IDEA的MyBatis/MyBatis-Plus开发插件,本文主要介绍了MybatisX快速生成增删改查的方法示例,文中通过示例代... 目录1 安装2 基本功能2.1 XML跳转2.2 代码生成2.2.1 生成.xml中的sql语句头2

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

一文教你Java如何快速构建项目骨架

《一文教你Java如何快速构建项目骨架》在Java项目开发过程中,构建项目骨架是一项繁琐但又基础重要的工作,Java领域有许多代码生成工具可以帮助我们快速完成这一任务,下面就跟随小编一起来了解下... 目录一、代码生成工具概述常用 Java 代码生成工具简介代码生成工具的优势二、使用 MyBATis Gen

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

SpringBoot快速搭建TCP服务端和客户端全过程

《SpringBoot快速搭建TCP服务端和客户端全过程》:本文主要介绍SpringBoot快速搭建TCP服务端和客户端全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录TCPServerTCPClient总结由于工作需要,研究了SpringBoot搭建TCP通信的过程

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

快速修复一个Panic的Linux内核的技巧

《快速修复一个Panic的Linux内核的技巧》Linux系统中运行了不当的mkinitcpio操作导致内核文件不能正常工作,重启的时候,内核启动中止于Panic状态,该怎么解决这个问题呢?下面我们就... 感谢China编程(www.chinasem.cn)网友 鸢一雨音 的投稿写这篇文章是有原因的。为了配置完

Python利用ElementTree实现快速解析XML文件

《Python利用ElementTree实现快速解析XML文件》ElementTree是Python标准库的一部分,而且是Python标准库中用于解析和操作XML数据的模块,下面小编就来和大家详细讲讲... 目录一、XML文件解析到底有多重要二、ElementTree快速入门1. 加载XML的两种方式2.

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析