程序3-4 竖式问题

算法竞赛入门经典(第2版)第3章 数组和字符串

程序3-4 竖式问题

感悟。

1、对%5d等有新的认识,自左向右排布,左边多余部分,空格补齐。

2、能比较熟练的取出一个整数各个位置的数字。

3、人为的输小数据的枚举范围,如数字只在输入数字范围内选取,而不是简单的0-9选取。

4、能独立写出该代码,也算不易。

5、原书的代码比本人更妙。

6、判断运算各阶段数字是否在原数据范围,写得挺垃圾的。

附上代码:

环境Dev-cpp4.9.9.2

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


char s[20];
int b[20];
int length;
int finda(int a){
    int i;
    for(i=0;i<length;i++){
        if(b[i]==a)
            return 1;
    }
    return 0;
}
int findflag(int a){
    int flag=1;
    while(a){//取出各个位置的数字 
        flag&=finda(a%10);
        a/=10;
    }
    return flag;
}
int main(){
    int i,j,k,m,n;    
    int x,y,z;
    int flag;
    int count=0;
    scanf("%s",s);
    length=strlen(s);
    for(i=0;i<length;i++)//字符串字母转换成数字 
        b[i]=s[i]-'0';
    for(i=0;i<length;i++){//被乘数百位数 
        if(b[i]!=0){//被乘数百位数不能为零 
            for(j=0;j<length;j++){//被乘数十位数 
                for(k=0;k<length;k++){//被乘数个位数 
                    for(m=0;m<length;m++){//乘数十位数 
                        if(b[m]!=0){//乘数十位数不能为零 
                            for(n=0;n<length;n++){//乘数个位数 
                                flag=1;
                                x=(b[i]*100+b[j]*10+b[k])*b[n];
                                y=(b[i]*100+b[j]*10+b[k])*b[m];
                                z=(b[i]*100+b[j]*10+b[k])*(b[m]*10+b[n]);
                                flag&=findflag(x)&findflag(y)&findflag(z);
                                
                                if(flag){
                                    count++;
                                    printf("<%d>\n",count);
                                    printf("%5d\n",(b[i]*100+b[j]*10+b[k]));
                                    printf("X%4d\n",(b[m]*10+b[n]));
                                    printf("-----\n");
                                    printf("%5d\n",x);
                                    printf("%4d\n",y);
                                    printf("-----\n");
                                    printf("%5d\n",z);
                                }
                            }
                        }
                    }
                }
            }
        }
    }
    printf("The number of solutions = %d\n",count);
    return 0;
}


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值