码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • NOI / 2.4基本算法之分治-2991:2011


    如果您没有dev-c++,可使用线上编辑器:GDB online Debugger | Compiler - Code, Compile, Run, Debug online C, C++。

    题目 

    连接:OpenJudge - 2991:2011

    总时间限制: 1000ms内存限制: 65536kB

    描述

    已知长度最大为200位的正整数n,请求出2011^n的后四位。

    输入

    第一行为一个正整数k,代表有k组数据,k<=200接下来的k行,

    每行都有一个正整数n,n的位数<=200

    输出

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

    样例输入

    1. 3
    2. 5
    3. 28
    4. 792

    样例输出

    1. 1051
    2. 81
    3. 5521

    首先要解决3个问题

    一、a有200位,往哪里存?int只能存十位数,long也只能存十九位、但如果用字符串来接,就会轻松很多。

    二、计算时会爆int,所以要边乘边%10000。

    三、把a存入后怎么用?很显然,我们要用取字符串的方法取出后三位,因为2011的乘方每500个一周期。

    完整程序+注释

    1. #include
    2. using namespace std;
    3. int main()
    4. {
    5. char a[2000];//200位数只能用字符串接
    6. int n,i,k,s,len;//s为累乘变量、i用来循环
    7. cin>>k;//输入组数
    8. while(k--)//循环k次
    9. {
    10. cin>>a;
    11. len=strlen(a);//判断字符长度
    12. s=1;//s:2011^n的结果
    13. if(len==1)//取后三位数
    14. n=a[0]-'0';
    15. if(len==2)
    16. n=(a[0]-'0')*10+a[1]-'0';
    17. if(len>=3)
    18. n=(a[len-3]-'0')*100+(a[len-2]-'0')*10+a[len-1]-'0';
    19. for(i=1;i<=n;i++)
    20. s=(s*2011)%10000;//保留后四位数
    21. cout<
    22. }
    23. }
  • 相关阅读:
    设计模式---代理模式
    管理类联考——数学——汇总篇——知识点突破——数据分析——计数原理——排列组合——排队
    【分类讨论】CF1834D
    OA项目之我的会议(会议排座&送审)
    Logical matrix
    【Java 进阶篇】Java Cookie共享:让数据穿越不同应用的时空隧道
    数据结构与算法-(11)---有序表(OrderedList)
    万物并作,吾以观复|OceanBase 政企行业实践
    k8s之从internal version到runtime.condec
    【C/C++】用C语言写一个数据仓库,存储和修改数据
  • 原文地址:https://blog.csdn.net/mooczhimahu/article/details/126150604
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号