`

以前做的一道机试题

阅读更多
原题大概是这样的:输入一个数,将这个数因式分解,并将结果按特定格式打印出来。
比如,输入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月以前机试题汇总

    本资源为"计算机二级考试VF2010年9月以前机试题汇总",包含了自2010年9月以前的85套VF机试题,这些试题是考生复习备考的重要参考资料。通过这些试题,考生可以熟悉考试的题型、难度以及考试的评分标准,从而有针对性...

    历年机试题大数据分析1

    自2008年至2019年,试题数量保持在2-3道之间,其中2016年以前每年3道,之后则减至2道,暗示着题目的深度可能在增加。分析历年题目类型,我们可以看到四大核心领域:数学问题、字符串问题、矩阵问题和基本算法问题,...

    大连理工大学考博英语 2007年详细解析及试题

    7. **2007年试题**:分析多年以前的试题,可以帮助考生了解考试的历史演变,对比现在,了解英语考试的标准是否有所变化,以及可能的未来趋势。 8. **备考策略**:基于这样的详细解析,考生可以制定有效的备考计划,...

    软件设计师15年及以前几年真题

    对于每一道真题,都需要仔细研究其背后的理论知识,理解解题思路,同时,参考答案的解析可以帮助深化理解,掌握解题技巧。如果可能的话,与他人讨论交流,分享不同的解题方法,可以拓宽视野,提高解决问题的能力。 ...

    湖北省孝感市孝南区七年级语文下学期期中调研考试试题(扫描版) 试题.doc

    3. **阅读理解**:一道题目涉及到对文本内容的理解,比如文中提到的战争场景,要求学生概述其特征,这需要学生具备一定的阅读理解能力和概括能力。 4. **文言文翻译**:文档中包含了文言文的翻译练习,如“你现在的...

    河北省张家口市2020届高三数学11月阶段检测试题 理 答案

    对于等比数列,关键要掌握其定义:若数列中的任意一项除以前一项都得到一个常数,则该数列为等比数列,这个常数称为公比。等比数列的通项公式是`a_n = a_1 * q^(n-1)`,其中`a_1`是首项,`q`是公比。 第二题考察了...

    【软件考证】软件设计师考试学习笔记(干货)及资料

    5.模拟考试试题,重难点题目,建议冲刺阶段做,提升很大 6.模拟考试软件,安装之后可以随机抽题做,检测学习成果,很方便 B站视频教程:https://www.bilibili.com/video/BV1eK411L7Co 如果链接失效的话,在B站私聊我...

    华为机试一霸教你过华为机试e.docx

    机试之前,需要调整好自己的心态,不要觉得写程序很难,机试题很难。相信机试题永远是考察每个人的根底,根底是不会考的很偏的。 二、算法竞赛入门经典 需要买一本算法竞赛入门经典,这本书不同于普通的算法或者...

    江苏省江阴市长泾片2016届中考数学模拟试题.doc

    江苏省江阴市长泾片2016届中考数学模拟试题主要涵盖了初中数学的多个核心知识点,包括倒数、代数运算、统计分析、几何图形、方程与不等式、函数、三角形性质以及特殊多边形的计算。以下是这些知识点的详细解释: 1....

    部编版二年级道德与法治上册第二次月考考试题及答案【汇编】.pdf

    3. 学习习惯与进步:内容中有一道题目指出,“他每天都准时来到学校,成绩比以前进步多了”,这反映了良好的学习习惯对于个人学业发展的重要性,准时到校是培养良好学习习惯的一个重要方面。 4. 游戏规则与创新:...

    世界500强面试题.pdf

    第一篇 面试题 ................................................................................ 8 1.1. 简介 ................................................................................................

    河南省高三英语9月月考试题(无答案)新人教版 试题.doc

    "spend time doing sth." 表示“花费时间做某事”,所以第一空应填"waiting";"look forward to"是固定搭配,意为“期待”,所以第二空应填"to came"。故选B。 23. 这题考察动词词义辨析。"trap"意为“困住”;...

    2004~2011年海淀期末物理选择题练习题库2.0

    (按照试题模板和答案模板排版,不要改变页面模式,一道题占用一页,答案和试题要一一对应!然后将试题和答案一起发给我;我打包后,再发给你,即可使用!) 11. 谢谢您的使用,请多提宝贵建议。(邮箱:dingbin99@...

    ISchool随机抽题考试系统

    3. **随机抽题算法**:这是系统的核心部分,需要设计一个智能的算法,根据预设的规则(如每科至少一道题,难易度均衡等)随机选取试题,确保每次抽取的题目组合都是唯一的。 4. **用户界面设计**:用户界面应当简洁...

    教你如何过华为机试.docx

    需要相信,机试题永远是考察每个人的基础,基础是不会考的很偏的。 2. 买一本《算法竞赛入门经典》,这本书不同于普通的算法或者编程语言的书籍,这本书既讲语言,又讲算法,由浅入深,讲的很好,能看完前几章并且把...

    2021-2022计算机二级等级考试试题及答案No.14389.docx

    下面将详细解析每一道题目涉及的概念和技术细节。 ### 数据库的相关概念 1. **数据库(DB)、数据库系统(DBS)、数据库管理系统(DBMS)的关系:** - **数据库(DB)**:存储在计算机系统中的、组织起来的相关...

    50用户在线考试系统

    试卷用倒计时方式扣减时间,如果考生在考试过程中不小心关闭窗口,可以重新进入考试系统,继续刚才的考试,以前保存的答案仍旧存在。 操作题一般来说用于信息化的考试,比如制作Word文档、Excel表格、网页制作等,...

    怀来2016年事业编招聘考试真题及答案解析完整版(1).docx

    6. 多媒体知识:指出多媒体与传统媒体的不同在于它可以传输图像、声音等,并能实现人机交互,涉及信息传播和信息技术。 7. 逻辑运算题:“一只天平有7克、2克砝码各一个,如果需要将140克的盐分成50克、90克各一份...

    气压计的故事

    盖尔曼很久以前,我接到我的同事的一个电话,他问我愿不愿意为一个试题的评分作鉴定人,好像是他想给他的一个学生答的一道物理试题打零分,而他的学生则声称他应该得满分,这位学生认为如果这种测验

Global site tag (gtag.js) - Google Analytics