问题 F: 深入浅出学算法022-天使的起誓

p.s.个人收录用

题目描述

Tenshi非常幸运地被选为掌管智慧之匙的天使。在正式任职之前,她必须和其他新当选的天使一样要宣誓。

宣誓仪式是每位天使各自表述自己的使命,他们的发言稿放在n个呈圆形排列的宝盒中。这些宝盒按顺时针方向被编上号码1,2,…,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

输出

只有一行(包括换行符),即天使想找的宝盒的编号。

样例输入 Copy
【输入样例1】
7
9
【输入样例2】
11
108
样例输出 Copy
【输出样例1】
2
【输出样例2】
9
代码
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <math.h>
#include <string.h>

//天使的起誓
//高精度:取余=除法(高/低)+减法

int main()
{
	char s1[2000];
	int a[2000], c[2000];
	int d[2000], e[2000];
	int b;
	scanf("%d", &b);
	scanf("%s", s1);
	int l1 = strlen(s1);
	memset(a, 0, sizeof(a));
	memset(c, 0, sizeof(c));
	memset(d, 0, sizeof(d));
	memset(e, 0, sizeof(e));
	for (int i = 0; i < l1; i++)
	{
		a[i] = s1[i] - '0';
	}
	//计算位数
	int b0 = b;
	int j;
	for (j = 0;; j++)
	{
		if (b0 == 0)
			break;
		b0 /= 10;
	}
	int k = 0;
	for (int i = 0; i < l1; i++)
	{
		k = k * 10 + a[i];
		c[i] = k / b;
		k %= b;
	}
	for (int i = 1; i <= l1; i++)
	{
		int ans = c[l1 - i] * b;
		int q = 0;
		while (ans)
		{
			e[l1 - i - q] += ans % 10;
			ans /= 10;
			q++;
		}
	}
	for (int i = 1; i <= l1; i++)
	{
		int ch = a[l1 - i] - e[l1 - i];
		int q = 1;
		int ans = 10;
		while (ch < 0)
		{
			a[l1 - i] = 0;
			if (a[l1 - i - q] > 0)
			{
				a[l1 - i - q] -= 1;
				ch += ans;
			}
			else
			{
				q++;
				ans *= 10;
			}
		}
		d[l1 - i] += ch % 10;
		q = 0;
		while (ch > 0)
		{
			a[l1 - i - q] += ch % 10;
			ch /= 10;
			q++;
		}
	}
	int g = 0;
	for (g = 0;g<l1; g++)
	{
		if (d[g])
			break;
	}
	if (g == l1)//余数为0的情况
		printf("%d", b);
	for (int p=g;p<l1;p++)
	{
		printf("%d", d[p]);
	}
	printf("\n");
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值