蓝桥杯-2017模拟赛本科试题-猜算式-java
来源:互联网 发布:淘宝美工速成班 编辑:程序博客网 时间:2024/06/10 10:43
蓝桥杯-2017模拟赛本科试题-猜算式-java
题目
你一定还记得小学学习过的乘法计算过程,比如:
273
x 15
——–
1365
273
——–
4095
请你观察如下的乘法算式
***
x***
——–
***
***
***
——–
*****
星号代表某位数字,注意这些星号中,
0~9中的每个数字都恰好用了2次。
(如因字体而产生对齐问题,请参看图p1.jpg)
请写出这个式子最终计算的结果,就是那个5位数是多少?
注意:只需要填写一个整数,不要填写任何多余的内容。比如说明文字。
代码
public class Main { public static void main(String[] args) { /* * 该乘法算式按照格式一共有6个数,其中有5个三位数和一个5位数 * 此题穷举出最前面的两个三位数,即乘数与被乘数就可一算出其他的数 */ for (int i = 100; i < 1000; i++) { for (int j = 100; j < 1000; j++) { int num[] = new int[6]; //声明一个容量为6的整型数组来分别存放这6个数 num[0] = i; num[1] = j; num[2] = i * (j % 10); num[3] = i * (j / 10 % 10); num[4] = i * (j / 100); num[5] = i * j; //该算式的结果 if(num[2] >= 100 && num[2] < 1000 && num[3] >= 100 && num[3] < 1000 && num[4] >= 100 && num[4] < 1000 && num[5] >= 10000 && num[5] <100000){//判断该算式的格式是否满足题目所给要求 if (judge(num)) { System.out.println(num[5]); } } } } } private static boolean judge(int[] num) {//判断这6个数中,0-9这10个数字出现的次数是否都为2 int count[] = new int[10]; //存放0-9这是个数字出现的次数 for (int i = 0; i < num.length; i++) { int temp = num[i] ; //通过取余操作取出这六个数中的每一个数字 while (temp != 0) { count[temp % 10]++; temp /= 10 ; } } for (int i = 0; i < 10; i++) { if (count[i] != 2) { return false; } } return true; }}
结果
40096
1 1
- 蓝桥杯-2017模拟赛本科试题-猜算式-java
- 蓝桥杯-2017模拟赛本科试题-排列序数-java
- 2017蓝桥杯java本科模拟赛
- 蓝桥杯-2017模拟赛本科试题-字符串比较
- 蓝桥杯-2017模拟赛本科试题-风险度量
- 蓝桥杯2017模拟赛-猜算式
- 2017蓝桥杯模拟赛-猜算式
- 蓝桥杯模拟赛2017 猜算式
- 2017蓝桥杯 模拟赛 猜算式
- 蓝桥杯模拟赛 猜算式
- 蓝桥杯模拟赛-猜算式
- 蓝桥杯模拟赛:猜算式
- 2012蓝桥杯预赛试题本科c++古堡算式
- 蓝桥杯模拟 猜算式
- 2017年 蓝桥杯模拟赛,猜算式(纯暴力)
- 2017蓝桥杯模拟赛 Problem B: 猜算式(11分)
- 蓝桥杯2017模拟题-猜算式
- 2017蓝桥模拟赛 猜算式
- Numpy
- Container With Most Watert
- Java 9:继承2
- 差乘 点乘的利用
- 我的重生之路
- 蓝桥杯-2017模拟赛本科试题-猜算式-java
- sql多表连接查询时,连接条件的两个列具有相同的名字会重复
- 202. Happy Number
- leetcode155. Min Stack
- Okhttp的https的设置
- 基于Spring Boot和Spring Cloud实现微服务架构学习(三)-Spring Boot应用
- WebBroker 制作网站
- Object.prototype.toString_优就业
- iOS导航栏侧滑失效问题