1008 三连击
这个题很简单,没有什么难理解的,就是这里需要用到一个算法
题意让我们求每一个三连击的数,不如我们直接按照三连击条件筛选数,然后输出就好了
a[i%10]=a[i/10%10]=a[i/100]=a[i2%10]=a[i2/10%10]=a[i2/100]=a[i3%10]
=a[i3/10%10]=a[i3/100]=1;这个就是一个逆向思维的
然后将所有的a加起来如果是9说明每一个数都用了,也就是1~9都可以了,那就满足了
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<string>
#include<cmath>
#include<cstring>
using namespace std;
int v;//表示和
bool a[10]; /*布尔类型*/
int main()
{
for(int i=192;i<=327;i++)
{
memset(a,0,sizeof(a)); v=0;//清零
a[i%10]=a[i/10%10]=a[i/100]=a[i*2%10]=a[i*2/10%10]=a[i*2/100]=a[i*3%10]
=a[i*3/10%10]=a[i*3/100]=1;
//进行各个位枚举然后填数
for(int j=1;j<=9;j++) v+=a[j];//加起来,试试是否填对了
if(v==9) cout<<i<<" "<<i*2<<" "<<i*3<<endl;
}
return 0;
}
该博客介绍了一个编程问题,即寻找1008到327之间的所有整数,它们的每一位数字(包括原数、两倍和三倍)都相同。博主通过C++代码展示了如何实现这个算法,遍历并检查每个数字,如果满足条件则输出。
4397

被折叠的 条评论
为什么被折叠?



