Description
TENSHI非常幸运的被选为掌管智慧之匙的天使。在正式任职之前,她必须和其他新当选的天使一样,要宣誓。宣誓仪式是每位天使各自表述自己的使命,她们的发言稿被放在N个呈圆形排列的宝盒中。这些宝盒按顺时针方向被编上号码1、2、3……、N-1、N。一开始天使们站在编号为N的宝盒旁。她们各自手上都有一个数字,代表她们自己的发言稿所在的盒子是从1号盒子开始按顺时针方向的第几个。例如:有7个盒子,那么如果TENSHI手上的数字为9,那么她的发言稿所在盒子就是第2个。现在天使们开始按照自己手上的数字来找发言稿,先找到的就可以先发言。TENSHI一下子就找到了,于是她最先上台宣誓:“我将带领大家开启NOI之门……”TENSHI宣誓结束以后,陆续有天使上台宣誓。可是有一位天使找了好久都找不到她的发言稿,原来她手上的数字M非常大,她转了好久都找不到她想找的宝盒。
请帮助这位天使找到她想找的宝盒的编号。
Input
每组测试数据占2行,分别读入正整数N和M,其中N、M满足
2 ≤ N ≤ 108,2 ≤ M ≤ 101000
Output
输出所求宝盒的编号,占一行
Sample Input
7
9
11
108
Sample Output
2
9
思路:
由于是高精除以低精(做题要注意题目给的数据范围),所以无需按高精除法做,直接根据除法公式做即可,但是要注意的一点是,如果余数为零,则说明是标号最大的位置。
#include <cstdio>
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
int n;
char s[10009];
int a[10009];
while(cin>>n>>s)
{
memset(a,0,sizeof a);
int len=strlen(s);
for(int i=0;i<len;i++)
a[i]=s[i]-'0';
int x=0;//储存余数
for(int i=0;i<len;i++)
x=(x*10+a[i])%n;//取余式
if(x==0) cout<<n<<endl;
else cout<<x<<endl;
}
return 0;
}