动手动脑

实验一:了解for循环得到棋盘结构

(1) 程序:

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("\n");

}

}

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的格式:");

}

}

}

实验结果图:

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

首先根据老师给的课堂例子可以得出:

package mathchange;

import java.util.Scanner;

import javax.swing.plaf.synth.SynthStyle;

//zhanxinwu,November,06,2016

public class MathChange {

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)

{

MathChange nr = new MathChange ();

System.out.println("请输入一个想要转化的数字");

System.out.println("只支持整数(0~百万)");

//测试把一个四位的数字字符串变成汉字字符串、

Scanner scanner=new Scanner(System.in);

String m=scanner.nextLine();

System.out.println(nr.toHanStr(m));

}

}

运行结果图:

实验三:JDK所提供的BigInteger

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

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

package shuzuDaShu;

//zhanxinwu,November,06,2016

import java.util.Scanner;

public class Dashu {

public static int[]add(int []a,int []b){

int m=0;//位数

int[]c=new int[a.length];

for(int i=a.length-1;i>=0;i--) {

c[i]=a[i]+b[i]+m;

if(c[i]<10)

m=0;

else

{

c[i]=c[i]-10;

m=1;

}

}

return c;

}

public static int []jian(int []a,int[]b,int w){

int digit=0;

int[]c=new int[a.length];

for(int i=a.length-1;i>=0;i--)

{

if(w<=0)

{

c[i]=b[i]-a[i]-digit;

if(c[i]>=0)

{  digit=0;

}

else

{

c[i]=c[i]+10;

digit=1;

}

}

else

{

c[i]=a[i]-b[i]-digit;

if(c[i]>=0)

{digit=0;}

else

{

c[i]=c[i]+10;

digit=1;

}

}

}

return c;

}

public static void main(String[]args){

int a[]=new int[100];

int b[]=new int[100];

int m=0;

int n=0;

int s=0;

int t=0;int w=0;

Scanner in=new Scanner(System.in);

System.out.println("请输入第一个大数:");

String K=in.next();

System.out.println("请输入第二个大数:");

String H=in.next();

m=a.length-K.length();

n=b.length-H.length();

if(K.length()>H.length())

{

w=1;

}

else if (K.length()<H.length())

{

w=-1;

}

else

{w = K.compareTo(H);}

for (int i = 0; i < K.length(); i++)

{

a[m++] = K.charAt(i) - 48;

}

for (int j = 0; j < H.length(); j++)

{

b[n++] = H.charAt(j) - 48;

}

int[] c = Dashu.add(a, b);

for (int k = 0; k < c.length; k++)

{

if (c[k] > 0)

{

s = k;

break;

}

}

System.out.print("大数相加的结果为:");

for (int i = s; i < c.length; i++) {

System.out.print(c[i]);

}

System.out.println();

int[] d = Dashu.jian(a, b, w);

for (int k = 0; k < d.length; k++)

{

if (d[k] > 0)

{

t = k;

break;

}

}

System.out.print("大数相减的结果为:");

if (w < 0)

System.out.print("-");

for (int i = t; i < d.length; i++)

{

System.out.print(d[i]);

}

System.out.println();

System.out.println();

System.out.println();

System.out.println();

}

}

实验四:

(1) 设计思想:该程序应该建立数组,然后调用随机数赋值,然后通过消息框进行求和输出等等。

(2) 实验流程图:

(3)源代码

package shuzurRandom;

//zhanxinwu,November,06,2016

import javax.swing.JOptionPane;

public class ShuZuRandom {

public static void main(String[] args) {

// TODO 自动生成的方法存根

int s=0;

String result="";

int a[]=new int[10];//创建一个数组

for( int i=0;i<10;i++){

a[i]=(int)(Math.random()*1000+1);//生成1~1000的随机数

s+=a[i];

result+=a[i]+" ";

}

JOptionPane.showMessageDialog(null, result+"总和为:"+s);

}

}

(4)实验结果运行图:

(5) 误差分析:

该实验比其他几个来说相对简单,所以难点就是在给数组赋随机数值上。

Java的数组的作业11月06日的更多相关文章

  1. CocoaPods管理iOS项目 2018年11月06日

    一.创建Test工程项目 二.打开终端 当前pod版本(1.6.0.beta.2最新版本2018年11月06日)和gem源路径(https://gems.ruby-china.com): 1.cd+当 ...

  2. CocoaPods更新2018年11月06日16:06:48

    https://gems.ruby-china.org点进去就知道了…… CocoaPods命令 更新 sudo gem install -n /usr/local/bin cocoapods --p ...

  3. .NET Conf 2022 &ndash; 11 月 8 日至 10 日

    .NET Conf 2022 下周就正式开启了,时间是美国时间的 11月8日至10日..NET Conf 2022是一个免费的,为期三天的, 虚拟开发人员活动提供多种实时会话,其中包括来自社区和 .N ...

  4. 【¥200代金券、iPad等您来拿】 阿里云9大产品免费公测#10月9日-11月6日#

    #10.09-11.06#200元代金券.iPad大奖, 9大产品评测活动! 亲爱的阿里云小伙伴们: 云产品的多样性(更多的云产品)也是让用户深度使用云计算的关键.今年阿里云产品线越来越丰富,小云搜罗 ...

  5. 11月30日《奥威Power-BI智能分析报表制作方法》腾讯课堂开课啦

    这么快一周就过去了,奥威公开课又要与大家见面咯,上节课老师教的三种报表集成方法你们都掌握了吗?大家都知道,学习的结果在于实际应用,想要熟练掌握新内容的要点就在于去应用它.正是基于这一要点,每一期的课程 ...

  6. 11月23日《奥威Power-BI报表集成到其他系统》腾讯课堂开课啦

    听说明天全国各地区都要冷到爆了,要是天气冷到可以放假就好了.想象一下大冷天的一定要在被窝里度过才对嘛,索性明天晚上来个相约吧,相约在被窝里看奥威Power-BI公开课如何?        上周奥威公开 ...

  7. 11月16日《奥威Power-BI基于SQL的存储过程及自定义SQL脚本制作报表》腾讯课堂开课啦

           上周的课程<奥威Power-BI vs微软Power BI>带同学们全面认识了两个Power-BI的使用情况,同学们已经迫不及待想知道这周的学习内容了吧!这周的课程关键词—— ...

  8. 11月09日《奥威Power-BI vs微软Power BI》腾讯课堂开课啦

    上过奥威公开课的同学可能有一个疑问:奥威Power-BI和微软Power BI是同一个吗,为什么叫同样的名字?正如这个世界上有很多个John.Jack.Marry…一样,奥威Power-BI和微软Po ...

  9. 2016年11月30日 星期三 --出埃及记 Exodus 20:21

    2016年11月30日 星期三 --出埃及记 Exodus 20:21 The people remained at a distance, while Moses approached the th ...

随机推荐

  1. 你该用HTTP2了

    更多内容,欢迎关注微信公众号:全菜工程师小辉.公众号回复关键词,领取免费学习资料. HTTP版本简史 HTTP/0.9: (1991年)基于GET请求的文本传输协议 HTTPS: (1994年)安全的 ...

  2. 【LeetCode】230#二叉搜索树中第K小的元素

    题目描述 给定一个二叉搜索树,编写一个函数 kthSmallest 来查找其中第 k 个最小的元素. 说明: 你可以假设 k 总是有效的,1 ≤ k ≤ 二叉搜索树元素个数. 示例 1: 输入: ro ...

  3. android 端缓存清理的实现

    首先关于缓存清理,网上已经有太多的工具类,但是遗憾的是,基本上都不完善,或者说根本就不能用,而项目中又要求实现这个烂东西(其实这玩意真没一点屁用,毕竟第三方清理/杀毒软件都带这么一个功能),但是只好硬 ...

  4. jinja2批量生成python脚本

    ​ 在使用airflow的过程中需要大量的dag脚本进行性能测试,如果一个个去编写dag脚本未免太过麻烦,于是想到用python的jinja2模板引擎实现批量脚本生成. 先通过pip命令安装jinja ...

  5. STL中关于全排列next_permutation以及prev_permutation的用法

    这两个函数都包含在algorithm库中.STL提供了两个用来计算排列组合关系的算法,分别是next_permutation和prev_permutation. 一.函数原型 首先我们来看看这两个函数 ...

  6. charles 反向代理

    本文参考:charles 反向代理 这个比较有逼格了: 正向代理和反向代理的区别: 正向代理:是代理客户端,为客户端收发请求,使真实客户端对服务器不可见:在客户这一端的,替客户收发请求(类似现在正常使 ...

  7. MOOC C++笔记(四):运算符重载

    第四周:运算符重载 基本概念 运算符重载,就是对已有的运算符(C++中预定义的运算符)赋予多重的含义,使同一运算符作用于不同类型的数据时导致不同类型的行为. 运算符重载的目的是:扩展C++中提供的运算 ...

  8. [C++] C++中的宏定义详解

    转载自:C++中的宏定义 和 C++宏定义详解 一.#define解析     #define是C语言中提供的宏定义命令,其主要目的是为程序员在编程时提供一定的方便,并能在一定程度上提高程序的运行效率 ...

  9. CentOS 8 正式发布

    转载请注明:文章转载自 OSCHINA 社区 [http://www.oschina.net] 本文地址:https://www.oschina.net/news/110111/centos-8-re ...

  10. NET Core 3.0 新姿势 将AutoFac替换内置DI

    .NET Core 3.0 和 以往版本不同,替换AutoFac服务的方式有了一定的变化,在尝试着升级项目的时候出现了一些问题. 原来在NET Core 2.1时候,AutoFac返回一个 IServ ...