您的位置:首页 > 其它

竖式问题

2016-04-13 22:52 323 查看

问题描述

找出所有形如abc*de(三位数乘以两位数)的算式,使得在完整的竖式中,所有数字都属于一个特定的数字集合。输入数字集合(相邻数字之间没有空格),输出所有竖式。每个竖式前应有编号,之后应有一个空行。最后输出的解的总数。


样例

输入

2357


输出

<1>
..775
X..33
-----
.2325
2325.
-----
25575

The number of solutions=1


代码

/*竖式问题
算法竞赛入门P42页
*/

#include<stdio.h>
#include<string.h>

int main(){
int count=0;
char s[100],buff[100];
scanf("%s",s);
for(int abc=111;abc<=999;abc++){
for(int de=11;de<=99;de++){
int x=abc*(de%10);
int y=abc*(de/10);
int z=abc*de;
sprintf(buff,"%d%d%d%d%d",abc,de,x,y,z);
int flag=1;
for(int i=0;i<strlen(buff);i++){
if(strchr(s,buff[i])==NULL) flag=0;
}
if(flag){
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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: