• Java06-动手动脑及课后作业


    1、阅读QiPan.java示例程序了解如何利用二维数组和循环语句绘制五子棋盘。

    package 练习;
    import java.io.*;
    
    public class QiPan
    {
    	//定义一个二维数组来充当棋盘
    	private String[][] board;
    	//定义棋盘的大小
    	private static int BOARD_SIZE = 15;
    	public void initBoard()
    	{
    		//初始化棋盘数组
    		board = new String[BOARD_SIZE][BOARD_SIZE];
    		//把每个元素赋为"╋",用于在控制台画出棋盘
    		for (int i = 0 ; i < BOARD_SIZE ; i++)
    		{
    			for ( int j = 0 ; j < BOARD_SIZE ; j++)
    			{
    				board[i][j] = "╋";
    			}
    		}
    	}
    	//在控制台输出棋盘的方法
    	public void printBoard()
    	{
    		//打印每个数组元素
    		for (int i = 0 ; i < BOARD_SIZE ; i++)
    		{
    			for ( int j = 0 ; j < BOARD_SIZE ; j++)
    			{
    				//打印数组元素后不换行
    				System.out.print(board[i][j]);
    			}
    			//每打印完一行数组元素后输出一个换行符
    			System.out.print("
    ");
    		}
    	}
        public static void main(String[] args)throws Exception
        {
            QiPan gb = new QiPan();
    		gb.initBoard();
    		gb.printBoard();
    		//这是用于获取键盘输入的方法
    		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
    		String inputStr = null;
                    System.out.println("请输入您下棋的座标,应以x,y的格式:");
    		//br.readLine():每当在键盘上输入一行内容按回车,刚输入的内容将被br读取到。
    		while ((inputStr = br.readLine()) != null)
    		{
    			//将用户输入的字符串以逗号(,)作为分隔符,分隔成2个字符串
    			String[] posStrArr = inputStr.split(",");
    			//将2个字符串转换成用户下棋的座标
    			int xPos = Integer.parseInt(posStrArr[0]);
    			int yPos = Integer.parseInt(posStrArr[1]);
    			//把对应的数组元素赋为"●"。
    			gb.board[xPos - 1][yPos - 1] = "●";				
    			/*
    			 电脑随机生成2个整数,作为电脑下棋的座标,赋给board数组。
    			 还涉及
    				1.座标的有效性,只能是数字,不能超出棋盘范围
    				2.如果下的棋的点,不能重复下棋。
    				3.每次下棋后,需要扫描谁赢了
    			 */
    			gb.printBoard();
    			System.out.println("请输入您下棋的座标,应以x,y的格式:");
    		}
        }
    }
    

       定义了一个私有的二维数组作为棋盘。并定义了长度。之后打印符号使之连接起来作为棋盘在控制台显示。建立缓冲区用来读取输入的坐标。还用了一些方法将输入的坐标分割开以及对数组元素的重新赋值。

    2、请编写一个程序将一个整数转换为汉字读法字符串。比如“1123”转换为“一千一百二十三”。

    源代码:

    package Test;
    import java.util.Scanner;
    public class ShowChange
    {
    	private String[] hanArr = {"零" , "一" , "二" , "三" , "四" , 
    		"五" , "六" , "七" , "八" , "九"};
    	private String[] unitArr = {"十" , "百" , "千","万","十万","百万","千万","亿","十亿"};
    	/**
    	 * 把一个四位的数字字符串变成汉字字符串
    	 * @param numStr 需要被转换的四位的数字字符串
    	 * @return 四位的数字字符串被转换成的汉字字符串。
    	 */
    	private String toHanStr(String numStr)
    	{
    		String result = "";
    		int numLen = numStr.length();
    		//依次遍历数字字符串的每一位数字
    		for (int i = 0 ; i < numLen ; i++ )
    		{
    			//把char型数字转换成的int型数字,因为它们的ASCII码值恰好相差48
    			//因此把char型数字减去48得到int型数字,例如'4'被转换成4。
    			int num = numStr.charAt(i) - 48;
    			//如果不是最后一位数字,而且数字不是零,则需要添加单位(千、百、十)
    			if ( i != numLen - 1 && num != 0)
    			{
    				result += hanArr[num] + unitArr[numLen - 2 - i];
    			}
    			//否则不要添加单位
    			else
    			{
    				
    			       //上一个数是否为“零”,不为“零”时就添加
    				if(result.length()>0 && hanArr[num].equals("零") && result.charAt(result.length()-1)=='零')
    					continue;
    				result += hanArr[num];
    			}
    		}
    		//只有个位数,直接返回
    		if(result.length()==1)
    			return result;
    		
    		int index=result.length()-1;
    		while(result.charAt(index)=='零'){
    			index--;
    		}
    		if(index!=result.length()-1)
    			return result.substring(0,index+1);
    		else {
    			return result;
    		}
    	}
    
        public static void main(String[] args) 
        {   Scanner input = new Scanner(System.in);
        	ShowChange nr = new ShowChange();
    		System.out.println("请输入一个整数:(不超过十亿!)");
    		String num = input.next();
    		System.out.println(nr.toHanStr(num));
    		
        }
    }
    

    截图:

      

                                                                                                               

    更进一步,能否将数字表示的金额改为“汉字表达? 比如将“¥123.52”转换为“壹佰贰拾叁元伍角贰分”。

    源程序:                                

    package Test;
    import java.util.Scanner;
    public class  MoneyChange {
    
    public static void main(String[] args) {
    // TODO Auto-generated method stub
    
    Scanner in=new Scanner(System.in);
    System.out.println("输入一个数:");
    double a;
    a=in.nextDouble();
    System.out.println(digitUppercase(a));
    }
    public static String digitUppercase(double n) { 
    String fraction[] = { "角", "分"}; 
    String digit[] = { "零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"}; 
    String unit[][] = { { "元", "万", "亿"}, { "", "拾", "佰", "仟"}}; 
    
    String head = n < 0 ? "负" : ""; 
    n = Math.abs(n); 
    
    String s = ""; 
    for (int i = 0; i < fraction.length; i++) { 
    s += (digit[(int) (Math.floor(n * 10 * Math.pow(10, i)) % 10)] + fraction[i]).replaceAll("(零.)+", ""); 
    } 
    if (s.length() < 1) { 
    s = "整"; 
    } 
    int integerPart = (int) Math.floor(n); 
    
    for (int i = 0; i < unit[0].length && integerPart > 0; i++) { 
    String p = ""; 
    for (int j = 0; j < unit[1].length && n > 0; j++) { 
    p = digit[integerPart % 10] + unit[1][j] + p; 
    integerPart = integerPart / 10; 
    } 
    s = p.replaceAll("(零.)*零$", "").replaceAll("^$", "零") + unit[0][i] + s; 
    } 
    return head + s.replaceAll("(零.)*零元", "元").replaceFirst("(零.)+", "").replaceAll("(零.)+", "零").replaceAll("^整$", "零元整"); 
    }
    
    }
    

    截图:

     

    3、前面几讲介绍过JDK所提供的BigInteger能完成大数计算,如果不用它,直接使用数组表达大数,你能实现相同的功能吗?

      要求:(1)用你的大数类实现加和减两个功能

         (2)阅读BigInteger类源码,弄清楚它是使用什么算法实现加减乘除四种运算的?

         (3)通过互联网查找大数运算的相关资料,给你的大数类添加乘、除、求阶乘等其它功能。

     

    源代码:

    package Test;
    import java.util.Scanner;
    public class DaShu {
    
    public static void main(String[] args) {
    // TODO Auto-generated method stub
    String s1,s2;
    Scanner in=new Scanner(System.in);
    System.out.println("输入第一个大数:");
    s1=in.next();
    System.out.println("输入第二个大数:");
    s2=in.next();
    System.out.println(add(s1,s2));
    System.out.println(sub(s1,s2));
    
    }
    
    private static String add(String a, String b) 
    { 
    System.out.print("大数的加法:");
    char[] aa = new StringBuffer(a).reverse().toString().toCharArray(); 
    char[] bb = new StringBuffer(b).reverse().toString().toCharArray(); 
    int aLen = aa.length; 
    int bLen = bb.length; 
    
    int len = aLen > bLen ? aLen : bLen; 
    
    int[] result = new int[len + 1]; 
    for (int i = 0; i < len + 1; ++i) { 
    int aint = i < aLen ? aa[i] - '0' : 0; 
    int bint = i < bLen ? bb[i] - '0' : 0; 
    result[i] = aint + bint; 
    } 
    
    for(int i=0;i<result.length-1;++i){ 
    if(result[i]>=10){ 
    result[i+1] += result[i]/10; 
    result[i] %= 10; 
    } 
    } 
    
    boolean flag = true; 
    StringBuffer sb = new StringBuffer(len); 
    for(int i=len;i>=0;--i){ 
    if(result[i]==0&&flag){ 
    continue; 
    }else{ 
    flag=false; 
    } 
    sb.append(result[i]); 
    } 
    return sb.toString(); 
    } 
    public static String sub(String f, String s) { 
    System.out.print("大数的减法:"); 
    // 将字符串翻转并转换成字符数组 
    char[] a = new StringBuffer(f).reverse().toString().toCharArray(); 
    char[] b = new StringBuffer(s).reverse().toString().toCharArray(); 
    int lenA = a.length; 
    int lenB = b.length; 
    // 找到最大长度 
    int len = lenA > lenB ? lenA : lenB; 
    int[] result = new int[len]; 
    // 表示结果的正负 
    char sign = '+'; 
    // 判断最终结果的正负 
    if (lenA < lenB) { 
    sign = '-'; 
    } else if (lenA == lenB) { 
    int i = lenA - 1; 
    while (i > 0 && a[i] == b[i]) { 
    i--; 
    } 
    if (a[i] < b[i]) { 
    sign = '-'; 
    } 
    } 
    // 计算结果集,如果最终结果为正,那么就a-b否则的话就b-a 
    for (int i = 0; i < len; i++) { 
    int aint = i < lenA ? (a[i] - '0') : 0; 
    int bint = i < lenB ? (b[i] - '0') : 0; 
    if (sign == '+') { 
    result[i] = aint - bint; 
    } else { 
    result[i] = bint - aint; 
    } 
    } 
    // 如果结果集合中的某一位小于零,那么就向前一位借一,然后将本位加上10。其实就相当于借位做减法 
    for (int i = 0; i < result.length - 1; i++) { 
    if (result[i] < 0) { 
    result[i + 1] -= 1; 
    result[i] += 10; 
    } 
    } 
    
    StringBuffer sb = new StringBuffer(); 
    // 如果最终结果为负值,就将负号放在最前面,正号则不需要 
    if (sign == '-') { 
    sb.append('-'); 
    } 
    // 判断是否有前置0 
    boolean flag = true; 
    for (int i = len - 1; i >= 0; i--) { 
    if (result[i] == 0 && flag) { 
    continue; 
    } else { 
    flag = false; 
    } 
    sb.append(result[i]); 
    } 
    // 如果最终结果集合中没有值,就说明是两值相等,最终返回0 
    if (sb.toString().equals("")) { 
    sb.append("0"); 
    } 
    // 返回值  
    return sb.toString(); 
    } 
    }
    

    截图:

    课后作业:

      随机生成10个数,填充一个数组,然后用消息框显示数组内容,接着计算数组元素的和,将结果也显示在消息框中。

    设计思路:先定义一个数组,利用循环把产生的随机数填充该数组,通过提示框输出该数组以及该数组元素的和。

    程序流程图:

    源代码:

    package Test;
    import javax.swing.JOptionPane;
    public class ArraySuiji {
    
    public static void main(String[] args) {
    int sum=0;
    int []a=new int[10];
    String output=new String();
    for(int i=0;i<a.length;i++)
    {
    a[i]=(int)(Math.random()*100);
    }
    output+="a[10]={";
    for(int i=0;i<a.length;i++)
    {
    output+=a[i]+" ";
    }
    output+="}";
    for(int i=0;i<a.length;i++)
    {
    sum+=a[i];
    }
    output+="
    sum:"+sum;
    JOptionPane.showMessageDialog(null, output,"随机数组内容及数组元素之和:",
    JOptionPane.PLAIN_MESSAGE);
    }
    }
    

    截图:

      

                                                                                                                                                                                         

  • 相关阅读:
    swoole创建进程
    php中,posix_getpid() 和 getmypid() 有什么不同
    php查看进程
    初探PHP多进程
    nginx转发
    mime类型
    acwing 517. 信息传递
    LeetCode 1255 得分最高的单词集合 Maximum Score Words Formed by Letters
    LEETCODE 1254 统计封闭岛屿的数目 Number of Closed Islands
    算法问题实战策略 SORTGAME
  • 原文地址:https://www.cnblogs.com/huyangyang/p/6036070.html
Copyright © 2020-2023  润新知