【9106】天使的起誓
来源:互联网 发布:csgo职业选手数据 编辑:程序博客网 时间:2024/05/16 13:59
Time Limit: 10 second
Memory Limit: 2 MB
问题描述
TENSHI非常幸运的被选为掌管智慧之匙的天使。在正式任职之前,她必须和其他新当选的天使一样,要宣誓。宣誓仪式是每位天使各自表述自己的使命,她们的发言稿被放在N个呈圆形排列的宝盒中。这些宝盒按顺时针方向被编上号码1、2、3……、N-1、N。一开始天使们站在编号为N的宝盒旁。她们各自手上都有一个数字,代表她们自己的发言稿所在的盒子是从1号盒子开始按顺时针方向的第几个。例如:有7个盒子,那么如果TENSHI手上的数字为9,那么她的发言稿所在盒子就是第2个。现在天使们开始按照自己手上的数字来找发言稿,先找到的就可以先发言。TENSHI一下子就找到了,于是她最先上台宣誓:“我将带领大家开启NOI之门……”TENSHI宣誓结束以后,陆续有天使上台宣誓。可以有一位天使找了好久都找不到她的发言稿,原来她手上的数字M非常大,她转了好久都找不到她想找的宝盒。
任 务 :请帮助这位天使找到她想找的宝盒的编号。
Input
从文件输入的第一、二行分别读入正整数N和M,其中N、M满足
2 ≤ N ≤ 10^8,2 ≤ M ≤ 10^1000
Output
把所求宝盒的编号输出,(末尾加换行符)。
Sample Input
79
Sample Output
2
Sample Input2
11108
Sample Output2
9
【题解】
这题就是高精度除单精度。只不过是变成求余数而已。但要注意,如果余数为0.那么就是最后一个宝盒。比如 n==9,m == 9,这个时候 m%n == 0,天使应该选择第9个宝盒。
x = (x * 10+a[i]) % n;
这就是模拟笔算除法的情况。
【代码】
#include <cstdio>#include <string>#include <iostream>using namespace std;int n,m[2000];void input_data(){scanf("%d",&n); //输入n和高精度数字mstring ss;cin >> ss;m[0] = ss.size();for (int i = 1;i <= m[0];i++) //不用倒叙存储m[i] = ss[i-1] - '0';}void get_ans(){int x = 0;for (int i = 1;i <= m[0];i++) //模拟笔算除法的情况x= (x*10 + m[i])% n;if (x == 0)//如果余数为0 则选择最后一个宝盒x = n;printf("%d\n",x);}int main(){input_data();get_ans();return 0;}
0 0
- 【9106】天使的起誓
- 【数论】[luoguP2818]天使的起誓
- 高精度之高精除以低精取余(天使的起誓)
- 我不是你的天使
- 半边翅膀的天使!
- 倒霉的天使
- 天使的失误
- 我是谁的天使
- 天使的礼物
- 天使的位阶
- 身边的天使
- 天使的礼物
- 堕天使的诞生
- 孩子的守护天使
- 天使的眼泪
- 我的奥运天使
- 天使的羽毛 (佚名)
- 不是我的天使
- List Clear和Remove区别
- Ios多线程学习笔记
- Gravatar 头像被墙及解决方案
- 137. Single Number II
- java关键字this的使用
- 【9106】天使的起誓
- 关系型数据库设计
- List笔记
- SDUT3343数据结构实验之二叉树四:还原二叉树
- Debian 更新 update 出现 没有公钥 的解决办法
- 正则表达式中各种字符的含义
- HDU 1010 DFS算法加剪枝(优化)
- JAVA图形用户界面
- MySQL原来也有内存数据库