原题大概是这样的:输入一个数,将这个数因式分解,并将结果按特定格式打印出来。
比如,输入10,得到2*5,则要显示成
就和计算器显示的一样。
下面是代码,整体思路就是每个基本数字都有7个显示位置,全显示就是0,1就是最右边两个竖。
package com.baidu;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
import java.util.Scanner;
public class Calculator {
private static int[] METRIX_0 = {1,1,1,0,1,1,1};
private static int[] METRIX_1 = {0,0,1,0,0,1,0};
private static int[] METRIX_2 = {1,0,1,1,1,0,1};
private static int[] METRIX_3 = {1,0,1,1,0,1,1};
private static int[] METRIX_4 = {0,1,1,1,0,1,0};
private static int[] METRIX_5 = {1,1,0,1,0,1,1};
private static int[] METRIX_6 = {1,1,0,1,1,1,1};
private static int[] METRIX_7 = {1,0,1,0,0,1,0};
private static int[] METRIX_8 = {1,1,1,1,1,1,1};
private static int[] METRIX_9 = {1,1,1,1,0,1,1};
private static String SPACE = " ";
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner in = new Scanner(System.in);
while(in.hasNext()){
int num = in.nextInt();
List<Integer> list = Factorize(num);
print(list);
}
}
public static void print(List<Integer> list){
int size = list.size();
//7个位置分开打印
for(int i = 0; i < 7; i++){
for(int j = 0; j < size; j++){
printFactor(i,list.get(j));
// 位置3比较特殊,
if( i == 3 ){
if(j < size - 1){
System.out.print("*");
}else{
System.out.print(SPACE);
}
}else{
System.out.print(SPACE);
}
}
if(i == 1 || i == 4){
i++;
}
if(i == 0 || i == 2 || i == 3 || i == 5){
System.out.println();
}
}
System.out.println();
}
/**
* 把大于10的数按每位数组合成数组,比如13转换成【1,3】
* @param num
* @return
*/
public static List<Integer> rebuild(int num){
List<Integer> array = new LinkedList<Integer>();
while(num >= 10){
array.add(num % 10);
num = num / 10;
}
array.add(num);
List<Integer> result = new ArrayList<Integer>();
for(int i = array.size() -1;i>=0;i--){
result.add(array.get(i));
}
return result;
}
/**
* 打印因数
* @param pos
* @param factor
*/
public static void printFactor(int pos,int factor){
if(factor >= 10){
List<Integer> array = rebuild(factor);
for(Integer ii : array){
printElem(pos,ii);
//每个基本数字打印后,加一个空格
// System.out.print(SPACE);
//因为位置1和位置2在同一行,位置4和位置5在同一行,所以位置1输出后,继续输出2.
int k = pos;
if(k == 1 || k == 4){
printElem(++k,ii);
}
}
} else {
printElem(pos,factor);
int k = pos;
if(k == 1 || k == 4){
printElem(++k,factor);
}
}
}
/**
* 基本数字0到9的每一行打印
* @param pos
* @param j
*/
public static void printElem(int pos,int j){
// 找到对应数字的矩阵
int[] arr = adapter(j);
// 位置是0,3,6的时候,需要输出横线 -
if(pos == 0 || pos == 3 || pos == 6){
// 为了美观,可以先输出一个空格
System.out.print(SPACE);
if(arr[pos] == 1){
System.out.print("-");
}else{
System.out.print(SPACE);
}
// 为了美观,再补上一个空格
System.out.print(SPACE);
}
// 其余位置输出|线
else{
if(arr[pos] == 1){
System.out.print("|");
}else{
System.out.print(SPACE);
}
// 当位置是1和4的时候,输出1和2,4和5之间的空格
if(pos == 1 || pos == 4){
System.out.print(SPACE);
}
}
}
public static int[] adapter(int num){
switch(num){
case 0:
return METRIX_0;
case 1:
return METRIX_1;
case 2:
return METRIX_2;
case 3:
return METRIX_3;
case 4:
return METRIX_4;
case 5:
return METRIX_5;
case 6:
return METRIX_6;
case 7:
return METRIX_7;
case 8:
return METRIX_8;
case 9:
return METRIX_9;
default:
return null;
}
}
//因式分解
public static List<Integer> Factorize(int n){
int key=1;
int num=n;
ArrayList<Integer> list=new ArrayList<Integer>();
while(num>1){
for(int i=2;i<=num;i++){ //从2开始除到本身,用于判断素数
if(num%i==0){ //找到素数因子
key=i;
list.add(key); //保存这个素数因子
break;
}
}
num=num/key; //继续分解除以素数因子得到的商
}
return list;
}
}
- 大小: 9.2 KB
分享到:
相关推荐
本资源为"计算机二级考试VF2010年9月以前机试题汇总",包含了自2010年9月以前的85套VF机试题,这些试题是考生复习备考的重要参考资料。通过这些试题,考生可以熟悉考试的题型、难度以及考试的评分标准,从而有针对性...
自2008年至2019年,试题数量保持在2-3道之间,其中2016年以前每年3道,之后则减至2道,暗示着题目的深度可能在增加。分析历年题目类型,我们可以看到四大核心领域:数学问题、字符串问题、矩阵问题和基本算法问题,...
7. **2007年试题**:分析多年以前的试题,可以帮助考生了解考试的历史演变,对比现在,了解英语考试的标准是否有所变化,以及可能的未来趋势。 8. **备考策略**:基于这样的详细解析,考生可以制定有效的备考计划,...
对于每一道真题,都需要仔细研究其背后的理论知识,理解解题思路,同时,参考答案的解析可以帮助深化理解,掌握解题技巧。如果可能的话,与他人讨论交流,分享不同的解题方法,可以拓宽视野,提高解决问题的能力。 ...
3. **阅读理解**:一道题目涉及到对文本内容的理解,比如文中提到的战争场景,要求学生概述其特征,这需要学生具备一定的阅读理解能力和概括能力。 4. **文言文翻译**:文档中包含了文言文的翻译练习,如“你现在的...
对于等比数列,关键要掌握其定义:若数列中的任意一项除以前一项都得到一个常数,则该数列为等比数列,这个常数称为公比。等比数列的通项公式是`a_n = a_1 * q^(n-1)`,其中`a_1`是首项,`q`是公比。 第二题考察了...
5.模拟考试试题,重难点题目,建议冲刺阶段做,提升很大 6.模拟考试软件,安装之后可以随机抽题做,检测学习成果,很方便 B站视频教程:https://www.bilibili.com/video/BV1eK411L7Co 如果链接失效的话,在B站私聊我...
机试之前,需要调整好自己的心态,不要觉得写程序很难,机试题很难。相信机试题永远是考察每个人的根底,根底是不会考的很偏的。 二、算法竞赛入门经典 需要买一本算法竞赛入门经典,这本书不同于普通的算法或者...
江苏省江阴市长泾片2016届中考数学模拟试题主要涵盖了初中数学的多个核心知识点,包括倒数、代数运算、统计分析、几何图形、方程与不等式、函数、三角形性质以及特殊多边形的计算。以下是这些知识点的详细解释: 1....
3. 学习习惯与进步:内容中有一道题目指出,“他每天都准时来到学校,成绩比以前进步多了”,这反映了良好的学习习惯对于个人学业发展的重要性,准时到校是培养良好学习习惯的一个重要方面。 4. 游戏规则与创新:...
第一篇 面试题 ................................................................................ 8 1.1. 简介 ................................................................................................
"spend time doing sth." 表示“花费时间做某事”,所以第一空应填"waiting";"look forward to"是固定搭配,意为“期待”,所以第二空应填"to came"。故选B。 23. 这题考察动词词义辨析。"trap"意为“困住”;...
(按照试题模板和答案模板排版,不要改变页面模式,一道题占用一页,答案和试题要一一对应!然后将试题和答案一起发给我;我打包后,再发给你,即可使用!) 11. 谢谢您的使用,请多提宝贵建议。(邮箱:dingbin99@...
3. **随机抽题算法**:这是系统的核心部分,需要设计一个智能的算法,根据预设的规则(如每科至少一道题,难易度均衡等)随机选取试题,确保每次抽取的题目组合都是唯一的。 4. **用户界面设计**:用户界面应当简洁...
需要相信,机试题永远是考察每个人的基础,基础是不会考的很偏的。 2. 买一本《算法竞赛入门经典》,这本书不同于普通的算法或者编程语言的书籍,这本书既讲语言,又讲算法,由浅入深,讲的很好,能看完前几章并且把...
下面将详细解析每一道题目涉及的概念和技术细节。 ### 数据库的相关概念 1. **数据库(DB)、数据库系统(DBS)、数据库管理系统(DBMS)的关系:** - **数据库(DB)**:存储在计算机系统中的、组织起来的相关...
试卷用倒计时方式扣减时间,如果考生在考试过程中不小心关闭窗口,可以重新进入考试系统,继续刚才的考试,以前保存的答案仍旧存在。 操作题一般来说用于信息化的考试,比如制作Word文档、Excel表格、网页制作等,...
6. 多媒体知识:指出多媒体与传统媒体的不同在于它可以传输图像、声音等,并能实现人机交互,涉及信息传播和信息技术。 7. 逻辑运算题:“一只天平有7克、2克砝码各一个,如果需要将140克的盐分成50克、90克各一份...
盖尔曼很久以前,我接到我的同事的一个电话,他问我愿不愿意为一个试题的评分作鉴定人,好像是他想给他的一个学生答的一道物理试题打零分,而他的学生则声称他应该得满分,这位学生认为如果这种测验