动手动脑

实验一:了解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. Disruptor中shutdown方法失效,及产生的不确定性源码分析

    版权声明:原创作品,谢绝转载!否则将追究法律责任. Disruptor框架是一个优秀的并发框架,利用RingBuffer中的预分配内存实现内存的可重复利用,降低了GC的频率. 具体关于Disrupto ...

  2. 062 Python必备库-从Web解析到网络空间

    目录 一.概述 二.Python库之网络爬虫 2.1 Requests 2.2 Scrapy 2.3 pyspider 三.Python库之Web信息提取 3.1 Beautiful Soup 3.2 ...

  3. Maven项目使用Nexus作为远程仓库的settings.xml配置

    Maven项目使用Nexus作为远程仓库的settings.xml配置(转) 在自己电脑C:\Users\hanmm\.m2\下的setting.xml. 1.服务器配置 <server> ...

  4. 磁盘告警之---神奇的魔法(Sparse file)

      一.问题来源 半夜钉钉接到告警,某台机器的磁盘使用率少于20%,于是迷糊中爬起来,咔咔咔 find / -size +1G,咔咔咔,把几个只有4-5G的日志文件echo空值了一下,然后吓蒙了,刚刚 ...

  5. 从零开始入门 K8s| K8s 的应用编排与管理

    作者 | 张振 阿里巴巴高级技术专家 一.资源元信息 1. Kubernetes 资源对象 我们知道,Kubernetes 的资源对象组成:主要包括了 Spec.Status 两部分.其中 Spec ...

  6. python中os模块再回顾

    先看下我的文件目录结构 F:\PYTHON项目\ATM购物车\7月28 在此目录下的文件如下: 封装.py 模块os.sys复习.py 运行当前的文件是模块os.sys复习.py 1.获取当前文件所在 ...

  7. Spring Boot核心(基本配置)

    上一篇Spring Boot我们简单讲了如何快速创建一个SpringBoot项目. 大家都知道SpringBoot非常强大,可以轻松与各种工具集成,但是我们知其然,也必须知其所以然. 今天开始就和大家 ...

  8. JS基础-全方面掌握继承

    前言 上篇文章详细解析了原型.原型链的相关知识点,这篇文章讲的是和原型链有密切关联的继承,它是前端基础中很重要的一个知识点,它对于代码复用来说非常有用,本篇将详细解析JS中的各种继承方式和优缺点进行, ...

  9. 30 道 Vue 面试题

    前言 本文以前端面试官的角度出发,对 Vue 框架中一些重要的特性.框架的原理以问题的形式进行整理汇总,意在帮助作者及读者自测下 Vue 掌握的程度. 本文章节结构以从易到难进行组织,建议读者按章节顺 ...

  10. Vue学习之vue实例中的数据、事件和方法

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...