• C语言 · 猜算式 · 乘法竖式


    题目:猜算式

    你一定还记得小学学习过的乘法计算过程,比如:

       273

    x   15

    ------  

    1365  

    273

    ------  

    4095  

    请你观察如下的乘法算式

         ***

    x   ***

    --------    

         ***   

       ***  

    ***

    --------  

    *****  

    星号代表某位数字,注意这些星号中,0~9中的每个数字都恰好用了2次。 (如因字体而产生对齐问题,请参看图p1.jpg)

    条件:每个数字要出现两次、公式要成立、结果是五位数。

    请写出这个式子最终计算的结果,就是那个5位数是多少?

     1 #include<stdio.h>
     2 #include<string.h>
     3 int jinwei(int i,int *f){
     4     while(i>0){
     5         if(f[i%10]==2){
     6             return 0;
     7         }
     8         f[i%10]++;
     9         i/=10;
    10     }
    11     return 1;
    12 }
    13 bool check(int i,int j,int a,int b,int c,int d){
    14     int x[20]={i/100,(i/10)%10,i%10,j/100,(j/10)%10,j%10,a/100,(a/10)%10,a%10,b/100,(b/10)%10,b%10,c/100,(c/10)%10,c%10,d/10000,(d/1000)%10,(d/100)%10,(d/10)%10,d%10};
    15     int y[20]={0};
    16     for(int h=0;h<20;h++){
    17         y[x[h]]++;
    18     }
    19     for(int h=0;h<20;h++){
    20         if(y[h]!=2){
    21             return false;
    22         }else{
    23             return true;
    24         }
    25     }
    26 }
    27 int main(){
    28     int i,j;
    29     for(i=100;i<=999;i++){
    30         for(j=100;j<=999;j++){
    31             int f[10]={0};//数组初始化 
    32             int a = i*(j%10);//乘个位得 
    33             int b = i*((j/10)%10);//乘十位得
    34             int c = i*(j/100);//乘百位得
    35             
    36             if(a>=1000||b>=1000||c>=1000||i*j>=100000||a<100||b<100)
    37                 continue;
    38             
    39             if(!check(i,j,a,b,c,i*j))
    40                 continue;
    41 
    42             if(i<j && jinwei(i,f)&&jinwei(j,f)&&jinwei(i*j,f)&&jinwei(a,f)&&jinwei(b,f))
    43                 printf("%d %d %d %d %d %d
    ",i,j,a,b,c,i*j);
    44         }
    45     }
    46     return 0;
    47 }
  • 相关阅读:
    【Python学习笔记之三】lambda表达式用法小结
    Cisco Packet Tracer 6.0 实验笔记
    Kali Linux 下安装中文版输入法
    kali 2018.1安装教程
    Kali Linux菜单中各工具功能大全
    互联网电商购物车架构演变案例
    互联网业务场景下消息队列架构
    物流系统高可用架构案例
    高并发下海量容器案例一
    客服系统微服务架构的演化
  • 原文地址:https://www.cnblogs.com/panweiwei/p/6682838.html
Copyright © 2020-2023  润新知