java动脑公开课_java课堂动手动脑

实验任务一:阅读并运行示例PassArray.java.

1)源代码:

package demo;

//PassArray.java

//Passing arrays and individual array elements to methods

public class PassArray {

public static void main(String[] args) {

int a[] = { 1, 2, 3, 4, 5 };

String output = "The values of the original array are:\n";

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

output += "   " + a[i];

output += "\n\nEffects of passing array " + "element call-by-value:\n"

+ "a[3] before modifyElement: " + a[3];

modifyElement(a[3]);

output += "\na[3] after modifyElement: " + a[3];

output += "\n Effects of passing entire array by reference";

modifyArray(a); // array a passed call-by-reference

output += "\n\nThe values of the modified array are:\n";

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

output += "   " + a[i];

System.out.println(output);

}

public static void modifyArray(int b[]) {

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

b[j] *= 2;

}

public static void modifyElement(int e) {

e *= 2;

}

}

2)程序截图:

9788f5453c6bacbbdf3476ae72fbea8e.png

使用引用传递时,方法中更改了数组元素的值,直接修改了原始的数组元素。 使用值传递时,方法体中修改的仅是原始数组元素的一个拷贝。

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

源代码:

package demo;

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

}

}

}

1)实验结果截图:

363c5d6bb13f353830eac0263c647aeb.png

实验任务三:请编写一个程序将一个整数转换为汉字读法字符串。比如“1123”转换为“一千一百二十三”。 更进一步,能否将数字表示的金额改为“汉字表达? 比如将“¥123.52”转换为“壹佰贰拾叁元伍角贰分”。

1)程序设计思想:

2)源代码:

package demo;

import java.util.Scanner;

public class ZhuanHuan {

private String[] a={"零","壹","贰","叁","肆","伍","陆","柒","捌","玖"};

private String[] b={"十","百","千","万","十万 ","百万"};

private String[] c={"元","角","分"};

private String Change(String str)

{

String result="";

int numLen=str.length();

for(int i=0;i

{

int num=str.charAt(i)-48;

if(i!=numLen-1&&num!=0)

{

result+=a[num]+b[numLen-2-i];

}

else

{

if(result.length()>0&&a[num].equals("零")&&result.charAt(result.length()-1)=='零')

continue;

result+=a[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[])

{

ZhuanHuan nr=new ZhuanHuan();

Scanner in=new Scanner(System.in);

System.out.print("输入整数:");

String x=in.next();

System.out.print("转换后为:"+nr.Change(x));

}

}

进一步,金额的源代码:

package demo;

import java.util.Scanner;

public class ZhuanHuan {

private String[] a={"零","壹","贰","叁","肆","伍","陆","柒","捌","玖"};

private String[] b={"十","百","千","万"};

private String[] c={"元","角","分"};

private String Change(String str)

{

String result="";

int p=0;

int numLen=str.length();

for(int i=0;i

{

if(str.charAt(i)=='.')

{

p=i;

break;

}

}

for(int i=0;i

int num=str.charAt(i)-48;

if(i!=p-1&&num!=0)

{

result+=a[num]+b[p-2-i];

}

else

{

if(result.length()>0&&a[num].equals("零")&&result.charAt(result.length()-1)=='零')

continue;

result+=a[num];

}

}

result+=c[0];

for(int i=p+1;i

{

int num1=str.charAt(i)-48;

if(num1!=0)

{

result+=a[num1]+c[numLen-p-2];

}

else

result+=a[num1];

p--;

}

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[])

{

ZhuanHuan nr=new ZhuanHuan();

Scanner in=new Scanner(System.in);

System.out.print("输入金额:");

String x=in.next();

System.out.print("转换后为:"+nr.Change(x));

}

}

4)实验结果截图:

ccc9046347e357bb9cbb4748d4e3d80f.png

实验任务四:大数

(1) 源代码:

package demo;

import java.util.Scanner;

public class BigNum{

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

int wei=0;

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

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

{

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

if(c[i]<10)

wei=0;

else

{

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

wei=1;

}

}

return c;

}

public static int []sub(int []a,int[]b,int w)

{

int wei=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]-wei;

if(c[i]>=0)

{   wei=0;}

else

{

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

wei=1;

}

}

else

{

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

if(c[i]>=0)

{wei=0;}

else

{

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

wei=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 u=0;

Scanner in=new Scanner(System.in);

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

String aa=in.next();

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

String bb=in.next();

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

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

if(aa.length()>bb.length())

{

u=1;

}

else if (aa.length()

{

u=-1;

}

else

{u = aa.compareTo(bb);}

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

{

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

}

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

{

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

}

int[] c = BigNum.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 = BigNum.sub(a, b, u);

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

{

if (d[k] > 0)

{

t = k;

break;

}

}

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

if (u < 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();

}

}

(2) 程序截图

148fcf21ce615ac5b842e48bcbd1518f.png

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

(1) 程序设计思路:先定义一个数组,用random算法产生随机数,利用for循环将随机数导入数组中,遍历计算数组元素的和,然后输出即可。

(2) 源代码:

package demo;

import javax.swing.JOptionPane;

public class ArrayAdd {

public static void main(String args[]){

int []a=new int[10];

int sum=0;

String str="10个随机数为:"+"\n";

for(int i=0;i

{

int m=(int)(Math.random()*100);

a[i]=m;

str+=a[i]+"\n";

sum+=a[i];

}

str+="随机数的和为:"+sum;

JOptionPane.showMessageDialog(null,str,"结果",JOptionPane.INFORMATION_MESSAGE);

}

}

程序截图:

64f47e355d20a24e764f297338e650e2.png

(5)编程总结:学会了利用循环将随机数赋给数组,然后计算数组元素的和,遍历并输出,把问题从大化小,由繁化简,逐步分析,完成项目。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/329166.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

dotnet core开发体验之开始MVC

开始 在上一篇文章&#xff1a;dotnet core多平台开发体验 &#xff0c;体验了一把dotnet core 之后&#xff0c;现在想对之前做的例子进行改造&#xff0c;想看看加上mvc框架是一种什么样的体验&#xff0c;于是我就要开始诞生今天的这篇文章来分享我的感受了。 一、项目改造加…

Java时间处理第三方包:Joda-Time

转载自 Java时间处理第三方包&#xff1a;Joda-TimeJoda-Time provides a quality replacement for the Java date and time classes.Joda-Time is the de facto standard date and time library for Java prior to Java SE 8. Users are now asked to migrate to java.time (…

Visual Studio Code五月版本更新

开源项目、跨平台代码编辑器Visual Studio Code刚发布了其1.2版本&#xff08;虽然说是2016年5月发布&#xff0c;但其实是在6月交付的&#xff09;。和往常一样&#xff0c;这次发布的版本中对于很大一部分功能都进行了改善&#xff0c;其中最值得关注的可能是一种全新整合的终…

关于SimpleDateFormat时间格式化线程安全问题

转载自 关于SimpleDateFormat时间格式化线程安全问题昨天推送的文章《关于创建和销毁对象》一文中&#xff0c;2.1重复利用对象这一小节所举的SimpleDateFormat格式化时间的例子是不合适的&#xff0c;因为多线程场景下&#xff0c;SimpleDateFormat存在线程安全问题。在此&am…

聊聊ASP.NET Core默认提供的这个跨平台的服务器——KestrelServer

跨平台是ASP.NET Core一个显著的特性&#xff0c;而KestrelServer是目前微软推出了唯一一个能够真正跨平台的Server。KestrelServer利用一个名为KestrelEngine的网络引擎实现对请求的监听、接收和响应。KetrelServer之所以具有跨平台的特质&#xff0c;源于KestrelEngine是在一…

pdfbox java.lang.outofmemoryerror_Apache PDFBox 1.8.11 发布,Java 的 PDF 处理类

Apache PDFBox 1.8.11 发布&#xff0c;此版本是个增量 bug 修复版本&#xff0c;包括大量 bug 修复和改进。现已提供下载&#xff1a;主要改进内容&#xff1a;Bug 修复[PDFBOX-962] - All sort of Problems when importing Xfdf files into PDFs ->damaged pdfs and NPEs[…

Java8 Striped64 和 LongAdder

转载自 Java8 Striped64 和 LongAdder 数据 STRIPING 根据维基百科的这段说明&#xff1a;In computer data storage, data striping is the technique of segmenting logically sequential data, such as a file, so that consecutive segments are stored on different phys…

Roslyn项目系统简介

发布15年后&#xff0c;Microsoft终于开始替换Visual Studio中基于COM的C#和Visual Basic项目系统。Microsoft谈及很多有必要放弃目前所用系统的原因&#xff1a; 原生且基于COM单线程并与UI线程绑定难以通过和&#xff08;不同用途的&#xff09;子类型类扩展到聚合之外与Visu…

fastdfs 集群 java_FastDFS集群部署(转载 写的比较好)

之前介绍过关于FastDFS单机部署&#xff0c;详见博文&#xff1a;FastDFSNginx(单点部署)事例下面来玩下FastDFS集群部署&#xff0c;实现高可用(HA)服务器规划&#xff1a;跟踪服务器1【主机】(Tracker Server)&#xff1a;192.100.139.121跟踪服务器2【备机】(Tracker Server…

简析.NET Core 以及与 .NET Framework的关系

至2002微软公司推出.NET平台已近15年&#xff0c;在互联网快速迭代的浪潮中&#xff0c;许多语言已被淘汰&#xff0c;同时也有更多新的语言涌现&#xff0c;但 .Net 依然坚挺的站在系统开发平台的一线阵营中&#xff0c;并且随着.NET Core 即将到来(2016年6月27日)的正式版&am…

Jdk1.8 JUC源码增量解析(2)-atomic-LongAdder和LongAccumulator

转载自 Jdk1.8 JUC源码增量解析(2)-atomic-LongAdder和LongAccumulator功能简介&#xff1a;LongAdder是jdk1.8提供的累加器&#xff0c;基于Striped64实现。它常用于状态采集、统计等场景。AtomicLong也可以用于这种场景&#xff0c;但在线程竞争激烈的情况下&#xff0c;Long…

mysql 密码hash算法_如何用hash创建一个mySQL用户(‘sha256’,$salt.$password)?

我肯定错过了什么.我想为select-only事务设置数据库用户帐户,但mysql不允许我在创建用户帐户时选择密码的哈希方法.这失败了&#xff1a;GRANT SELECT ON myDB.* TO selectuserlocalhostIDENTIFIED BY hash(sha256, salted-myfakelongrandompasswordstring);错误1064(42000)&am…

为什么微软逐步转变为开源公司

微软目前拥有自己的 BSD Unix 操作系统&#xff0c;支持 Ubuntu 作为 Windows 10 的一个子系统&#xff0c;最近又将 Xamarin 软件开发工具包开源&#xff0c;所有这些意味着微软已不再是比尔盖茨和史蒂夫鲍尔默的微软了。 我知道这很难令人相信&#xff0c;但微软确实正大步走…

Jdk1.8 JUC源码增量解析(1)-atomic-Striped64

转载自 Jdk1.8 JUC源码增量解析(1)-atomic-Striped64功能简介&#xff1a;Striped64是jdk1.8提供的用于支持如Long累加器&#xff0c;Double累加器这样机制的基础类。Striped64的设计核心思路就是通过内部的分散计算来避免竞争(比如多线程CAS操作时的竞争)。Striped64内部包含…

java内部类选择题_java内部类详解(附相关面试题)

说起内部类这个词&#xff0c;想必很多人都不陌生&#xff0c;但是又会觉得不熟悉。原因是平时编写代码时可能用到的场景不多&#xff0c;用得最多的是在有事件监听的情况下&#xff0c;并且即使用到也很少去总结内部类的用法。今天我们就来一探究竟。一.内部类基础在Java中&am…

开源,新的平台之战

近日&#xff0c;OpenDaylight项目的执行总监Neela Jacques在文章《开源的转变&#xff1a;一种新的平台战争》 中提到&#xff1a;开源已经成为软件公司业务战略的关键&#xff0c;是一种新的平台之战。 多年来&#xff0c;开源软件似乎处于技术产业的边缘。而如今&#xff0c…

java下载图片到手机相册_Unity保存图片到Android手机且更新相册

Android 保存图片到设备前言:在许多的应用或游戏中,大多都有保存图片或者截图等等的功能,这篇文档我们的目的是通过 Unity 保存图片,并且调用 Andorid 中的更新相册的原生方法.流程步骤:编写更新相册的 Android 原生接口 -> Unity 编写保存图片逻辑以及调用更新相册 Android…

如何在 Java 中正确使用 wait, notify 和 notifyAll – 以生产者消费者模型为例

转载自 如何在 Java 中正确使用 wait, notify 和 notifyAll – 以生产者消费者模型为例 wait, notify 和 notifyAll&#xff0c;这些在多线程中被经常用到的保留关键字&#xff0c;在实际开发的时候很多时候却并没有被大家重视。本文对这些关键字的使用进行了描述。 在 Java 中…

.NET Core 使用Dapper 操作MySQL

.NET Core 使用Dapper 操作MySQL 数据库&#xff0c; .NET Core 使用Dapper。 目前官方没有出.NET Core MySQL 驱动&#xff0c;但是已经有第三方进行改动封装出.NET Core MySQL Connector 预览版。 Dapper 也已经出了 .NET Core 预览版。 Dapper dot net 是一个轻量型的ORM&a…

Angular 2与TypeScript概览

迄今为止&#xff0c;在创建Web应用方面&#xff0c;AngularJS是当前最为流行的JavaScript框架。如今&#xff0c;Angular 2和TypeScript通过一种非常类似于Java 8的语法&#xff0c;使真正面向对象的Web开发成为了主流。 据Google的工程主管Brad Green介绍&#xff0c;有130万…