天使的起誓

题目

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(int i=maxn-1;i>0;i--)if (a[i]>=b[i]+g){a[i]=a[i]-b[i]-g;g=0;}else{a[i]=10+a[i]-b[i]-g;g=1;}
}
bool comp(int a[],int b[])
{int i=0;while(a[i]==b[i]&&i<maxn)i++;if(i==maxn)return 1;return (a[i]>=b[i]);
}
void output()
{int i;i=1;while(a[i]==0&&i<maxn)i++;if(i==maxn)cout<<str1;else for(int j=i;j<maxn;j++)cout<<a[j];
}
void work()
{int j=1;while(comp(a,b)){j++;for(int i=2;i<maxn;i++){b[i-1]=b[i];b[i]=0;}}while (j>0){while(comp(a,b))sub();j--;for (int i=maxn-1;i>=1;i--) {b[i]=b[i-1];b[i-1]=0;}}
}
void init()
{memset(a,0,sizeof(a));memset(b,0,sizeof(b));memset(c,0,sizeof(c));scanf("%s%s",str1,str2);for(int i=0;i<strlen(str1);i++)b[maxn-strlen(str1)+i]=str1[i]-'0';for(int i=0;i<strlen(str2);i++)a[maxn-strlen(str2)+i]=str2[i]-'0';if(comp(a,b)==0||comp(b,a)==0)work();
}
int main()
{init();output();return 0;
}

SSL_1491【天使的起誓】(高精度减法)相关推荐

  1. 高精度题解:1745 天使的起誓(yubikili)

    背景 本题收藏于某OJ题库的高精度算法题单,解法参考SSL_wj 的题解,稍有改进. 原题 1745: 天使的起誓(yubikili) 题目描述 TENSHI非常幸运的被选为掌管智慧之匙的天使.在正式 ...

  2. luogu2818 天使的起誓(高/低)

    luogu2818  天使的起誓 时空限制    1000ms/128M 题目描述 Tenshi非常幸运地被选为掌管智慧之匙的天使.在正式任职之前,她必须和其他新当选的天使一样要宣誓.宣誓仪式是每位天 ...

  3. 【洛谷P2818】天使的起誓

    天使的起誓 题目链接:天使的起誓 题目描述 Tenshi非常幸运地被选为掌管智慧之匙的天使.在正式任职之前,她必须和其他新当选的天使一样要宣誓. 宣誓仪式是每位天使各自表述自己的使命,他们的发言稿放在 ...

  4. 高精度减法(C++实现)

    高精度减法 简介 用于计算含有超过一般变量存放不下的非负整数 高精度加法这个过程是模拟的小学竖式减法计算 注:在本文中,我们默认输入的第一个数为被减数,且被减数大于减数 原理基本上与高精度加法相同,仅 ...

  5. 洛谷 P2818 天使的起誓

    P2818 天使的起誓 题目描述 Tenshi非常幸运地被选为掌管智慧之匙的天使.在正式任职之前,她必须和其他新当选的天使一样要宣誓.宣誓仪式是每位天使各自表述自己的使命,他们的发言稿放在n个呈圆形排 ...

  6. 高精度减法(洛谷-P2142)

    题目描述 高精度减法 输入输出格式 输入格式: 两个整数a,b(第二个可能比第一个大) 输出格式: 结果(是负数要输出负号) 输入输出样例 输入样例#1: 2 1 输出样例#1: 1 源代码 #inc ...

  7. CCF NOI1139 高精度减法

    问题链接:CCF NOI1139 高精度减法. 时间限制: 1000 ms  空间限制: 262144 KB 题目描述 给两个正整数a和b,计算它们的差.题目保证a>=b 输入 两行每行一个数, ...

  8. (压位)高精度乘法,高精度加法,高精度减法,高精度除法

    大值 乘 大值: 题目链接:https://www.luogu.com.cn/problem/P1303 # include <iostream> # include <string ...

  9. 高精度算法——高精度减法

    介绍: 高精度减法也同加法一样,也是用于位数太大的运算,给你一个十几位的数你可能会做直接开个long long 的数据类型就解决了,但是给你一个100位的呢,1000位的呢,开long long 也不 ...

最新文章

  1. pycharm怎么修改语言为中文?(不用汉化包)
  2. 等了这么久,就给我看这个?
  3. 进程间通信 - 匿名管道实现
  4. 对于局部变量_2020年对于JDK ,大家觉得哪个版本好用?
  5. 约瑟夫环 猴子选大王的问题
  6. 三目运算符_Java中的三目运算符
  7. 全国计算机等级考试题库二级C操作题100套(第75套)
  8. 19_05_01校内训练[polygon]
  9. 富文本编辑器 CKeditor 配置使用
  10. 腾讯视频与中国电信签署战略合作协议 共同成立5G联合实验室
  11. 分拆素数和【筛选法】
  12. 关于opencv设置视频的属性无效问题
  13. 优酷网架构学习和揭秘
  14. FireMonkey ListView 设计期添加按钮及其 OnClick 事件
  15. MD5加密算法的原理
  16. C语言判断100以内的素数的两种方法
  17. bootstrap入门-1.可视化布局
  18. 你离成为程序员的梦想仅一“证”之遥
  19. 电脑开机显示“被调用的对象已与其客户端断开连接”解决方法
  20. 在WhatsApp中如何发起群发?

热门文章

  1. 详细介绍如何自研一款博客搬家功能
  2. 华为手机(P20)连接 Win10 传输文件
  3. ChatGPT的朋友们:大语言模型经典论文一次读到吐
  4. 中秋手机大换新 这几部爆款可以入手了
  5. 配置machineKey
  6. 华为数通笔记-双点双向引入
  7. Python 异步编程之——协程
  8. 删除数组中相同元素(C语言)
  9. 2009年最影响中国企业10大IT事件
  10. 用《饿狼传说》中的不知火舞女神来验证python模块中imshow()和show()的区别