SSL_1491【天使的起誓】(高精度减法)

天使的起誓

题目

TENSHI非常幸运的被选为掌管智慧之匙的天使。在正式任职之前,她必须和其他新当选的天使一样,要宣誓。宣誓仪式是每位天使各自表述自己的使命,她们的发言稿被放在N个呈圆形排列的宝盒中。这些宝盒按顺时针方向被编上号码1、2、3……、N-1、N。一开始天使们站在编号为N的宝盒旁。她们各自手上都有一个数字,代表她们自己的发言稿所在的盒子是从1号盒子开始按顺时针方向的第几个。例如:有7个盒子,那么如果TENSHI手上的数字为9,那么她的发言稿所在盒子就是第2个。现在天使们开始按照自己手上的数字来找发言稿,先找到的就可以先发言。TENSHI一下子就找到了,于是她最先上台宣誓:“我将带领大家开启NOI之门……”TENSHI宣誓结束以后,陆续有天使上台宣誓。可以有一位天使找了好久都找不到她的发言稿,原来她手上的数字M非常大,她转了好久都找不到她想找的宝盒。请帮助这位天使找到她想找的宝盒的编号。

输入

第一、二行分别读入正整数N和M,其中N、M满足2 ≤ N ≤ 10^8,2 ≤ M ≤ 10^1000

输出

求宝盒的编号

Sample Input

样例1

7
9

样例2

11
108

Sample Output

样例1

2

样例2

9

题意解析

这道题其实就是高精除求余,也就是疯狂高精减,但由于大小差距太大,N的大小是108,M的大小却是101000,暴力减会愉快的Time Limit Exceed,所以我们要用到移位的方法:
1234-12我们可以先用1234-1200=34
再用34-12=22
最后用22-12=10
结果就是10
华丽丽的代码分割线


代码

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
using namespace std;
const int maxn=1005;
char str1[maxn],str2[maxn];
int a[maxn],b[maxn],c[maxn];
void sub()
{
   
 int s,g=0;
    for
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值