I

F(x,m) 代表一个全是由数字x组成的m位数字。请计算,以下式子是否成立:

F(x,m) mod k ≡ c

Input

第一行一个整数T,表示T组数据。
每组测试数据占一行,包含四个数字x,m,k,c

1≤x≤9

1≤m≤1010

0≤c<k≤10,000

Output

对于每组数据,输出两行:
第一行输出:"Case #i:"。i代表第i组测试数据。
第二行输出“Yes” 或者 “No”,代表四个数字,是否能够满足题目中给的公式。

Sample Input

3
1 3 5 2
1 3 5 1
3 5 99 69

Sample Output

Case #1:
No
Case #2:
Yes
Case #3:
Yes

Hint

对于第一组测试数据:111 mod 5 = 1,公式不成立,所以答案是”No”,而第二组测试数据中满足如上公式,所以答案是 “Yes”。

问公式是否成立,因为位数太大,所以只能一点点取模,每次记录取模结果,如果发现重复了,那没就看之前取的是不是一样

#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include <iomanip>
#include<cmath>
#include<float.h> 
#include<string.h>
#include<algorithm>
#define sf scanf
#define pf printf
#define sca(x) scanf("%d",&x)
#define mm(x,b) memset((x),(b),sizeof(x))
#include<vector>
#include<queue>
#include<map>
#define rep(i,a,n) for (int i=a;i<n;i++)
#define per(i,a,n) for (int i=a;i>=n;i--)
typedef long long ll;
const ll mod=1e9+100;
const double eps=1e-8;
using namespace std;
const double pi=acos(-1.0);
const int inf=0xfffffff;
const int N=10005;
int bits;
int a[N],b[N];
void solve(ll x,ll m,ll k,ll c)
{
	pf("Case #%d:
",bits++);
	mm(a,0);mm(b,0);
	ll temp=0,ans=0;
	a[0]=1;
	ll cas=1;
	rep(i,0,m)
	{
		ans=(ans*10+x)%k;
		if(i+1==m&&ans==c)//如果结束了
		temp=1;
		else
		{
			if(a[ans])//之前是否有出现
			{
				if(b[m%cas]==c)//看剩下的能否于之前记录的相同
				temp=1;
				break;
			}else//没出现记录下状态
			{
				a[ans]=1;
				b[cas++]=ans;
			}
		}
	}
	if(temp)
	pf("Yes
");
	else
	pf("No
");
}
int main()
{
	int re;cin>>re;
	bits=1;
	while(re--)
	{
		ll x,m,k,c;
		cin>>x>>m>>k>>c;
		solve(x,m,k,c);
	}
	return 0;
}
原文地址:https://www.cnblogs.com/wzl19981116/p/9478051.html