#include<iostream>
#include<string.h>
using namespace std;
//三位数与两位数每位的乘积所得结果还有最终结果以及三位数,两位数,的每一个字符都要进行检验。
int main() {
int count=0;//n方阵的大小 ,x,y代表数组的横纵坐标,flag代表
char s[20],buf[99];
scanf("%s", s);
for(int abc=111;abc<=999;abc++)
for(int de=11;de<=99;de++)
{
int x=abc*(de%10),y=abc*(de/10),z=abc*de;
sprintf(buf,"%d%d%d%d%d",abc,de,x,y,z);//sprintf输出到字符串
int ok=1;
for(int i=0;i<strlen(buf);i++)
if(strchr(s,buf[i])==NULL) ok=0;//ok当作一个符合条件的标志 (这个思想可以get下来)
if(ok){
printf("<%d>\n",++count);
printf("%5d\nX%4d\n-----\n%5d\n%4d\n-----\n%5d\n\n",abc,de,x,y,z);
}
}printf("The number of solutions=%d\n",count);
return 0;
}
竖式问题
最新推荐文章于 2022-04-22 21:03:34 发布