Alice and Bob

该博客主要探讨了一种编程问题,涉及寻找特定长度的数字串(由Alice喜欢的n位数)中,哪些能被Bob喜欢的特定数m整除。通过分析和计算,博主给出了求解这类问题的算法,展示了如何处理数学与编程的结合问题。

题目描述

Alice喜欢n位数,Bob喜欢能被m整除的数,请问被Alice和Bob都喜欢的数有多少个?

输入

第一行是一个整数K(K≤10000),表示样例的个数。
每个样例是一行,两个整数n(1≤n≤18),m(2≤m≤1000000)。

输出

每行输出一个样例的结果。

样例输入

4
1 2
3 2
3 3
3 10000

样例输出

5
450
300
0
#include<stdio.h>
#include<math.h>
int main ()
{
	int K;
	scanf("%d",&K);
	while(K>0)
	{
		K--;
		int m,n;
		scanf("%d %d",&n,&m);
		__int64 count;
		if(n==1)
		{
			count=9/m;
			printf("%I64d\n",count+1);
			
		}
			else
			{
				__int64 a,b;
				a=pow(10,n)-1;
				a/=m;
				b=pow(10,n-1)-1;
				b/=m;
				count=a-b;
				printf("%I64d\n",count);
			}
	}
	return 0;
}
 

 

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

vernon-w

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值