整除的尾数 Problem - 2099

Text Reverse
Time Limit: 1000/1000 MS (Java/Others)
Memory Limit: 32768/32768 K (Java/Others)

Problem Description
一个整数,只知道前几位,不知道末二位,被另一个整数除尽了,那么该数的末二位该是什么呢?

Input
输入数据有若干组,每组数据包含二个整数a,b(0<a<10000, 10<b<100),若遇到0 0则处理结束。

Output
对应每组数据,将满足条件的所有尾数在一行内输出,格式见样本输出。同组数据的输出,其每个尾数之间空一格,行末没有空格。

Sample Input
200 40
1992 95
0 0

Sample Output
00 40 80
15

问题链接
Problem - 2099

问题简述:
已知一个整数的前几位以及能够将它除尽的整数,求该整数后两位尾数

问题分析:
求出能够被整除的最小整数,然后在此基础上增加除数的值。

程序说明:
求出能够被整除的最小整数,然后在此基础上增加除数的值。注意d-a<100这个条件的判定情况。

#include <iostream>
#include <iomanip>
using namespace std;

int main()
{
	int n, m,a,b,c,d;
	while(cin>>n>>m)
	{
		if(n==0&&m==0)
		break;
		a=n*100;
		b=a%m;
		if(b==0)
		c=a;
		else 
		c=a+m-b;
		d=c;
		for(int i=0;d-a<100;i++)
		{
			d=c+m*i;
			if(d-a<10)
			cout<<"0"<<d-a;
			else if(i==0)
			cout<<d-a;
			else if(d-a<100)
			cout<<" "<<d-a;
		}
		cout<<endl;
	}
	 return 0;
}

猜你喜欢

转载自blog.csdn.net/weixin_44012551/article/details/85007188
今日推荐