《Java技术》第一次作业——Java语言基础
学习总结
Scanner类实现基本数据输入的方法
Scanner 使用分隔符模式将其输入分解为标记,默认情况下该分隔符模式与空白匹配。然后可以使用不同的 next 方法将得到的标记转换为不同类型的值。
- 输入一个int型的值
import java.util.Scanner;
public class text{
public statuc void main(String[] args){
Scanner in=new Scanner(System.in);
int a=in.nextInt();
}
}
- 读取一个单词
import java.util.Scanner;
public class text{
public static void main(String[] args){
Scanner.in=new Scanner(System.in);
String stu="a";
a=in.next();
}
}
- 读取一行内容
Scanner.in=new Scanner(System.in);
nextLine();
.Random类和Math类的random()方法产生随机数的区别
- Random类的随机方法是设定随机种子,(new Random().nextInt(10),这里的10就是随机种子,根据随机数的原理,相同随机种子在相同的随机次数中产生的随机数是一样的。
使用Math.random()方法来产生一个随机数,这个产生的随机数是0-1之间的一个double类型,我们可以把他乘以一定的数,比如说乘以100,他就是个100以内的随机。
运行下列程序,结果是什么?查阅资料,分析为什么
public class Test {
public static void main(String args[]) {
double a = 0.1;
double b = 0.1;
double c = 0.1;
if((a + b + c) == 0.3){
System.out.println("等于0.3");
}else {
System.out.println("不等于0.3");
}
}
}
参照课本修改后的代码
import java.math.BigDecimal;
public class Test {
public static void main(String args[]) {
double a = 0.1;
double b = 0.1;
double c = 0.1;
double sum=0;
sum=Math.round(Math.add(a,c,b),1);
if(sum==0.3){
System.out.println("等于0.3");
}
else {
System.out.println("不等于0.3");
}
}
}
class Math{
public static double add(double a1,double a2,double a3){
BigDecimal x1=new BigDecimal(a1);
BigDecimal x2=new BigDecimal(a2);
BigDecimal x3=new BigDecimal(a3);
return x1.add(x2).add(x3).doubleValue();
}
public static double round(double d,int len){
BigDecimal x1=new BigDecimal(d);
BigDecimal x2=new BigDecimal(1);
return x1.divide(x2,len,BigDecimal.ROUND_HALF_UP).doubleValue();
}
}
运行结果:
实验总结
看商品猜价格
- 设计思路
1 生成一个随机数代表价格
2 输入猜到的价格
3 根据输入的价格和真实价格的关系给出提示信息 - 具体代码
import java.util.Scanner;
import java.util.Random;
public class Guessprices {
public static void main(String[] args){
Scanner in=new Scanner(System.in);
Random rand=new Random();
int price=rand.nextInt(100);
int guess,score,count=1;
String a="yes";
String str1="yes";
System.out.println("有五次的猜测机会");
while(a.equals(str1))/*判断是否运行猜价格的代码段*/{
score=100;
int i;
for(i=5;i>0;i--){
guess=in.nextInt();
if(guess!=price){
if(guess>price){
System.out.println("猜测数比答案大了,请重新输入,剩余猜测机会:"+(i-1));
count++;
}
else if(guess<price){
System.out.println("猜测数比答案小了,请重新输入,剩余猜测机会:"+(i-1));
count++;
}
score=score-20;
}
else if(guess==price){
System.out.println("答案正确 结果为:"+price+"一共猜测了"+count+"次,得分为:"+score);
}
}
if(i==0&&score==0){
System.out.print("此次机会已用完,是否进行下一轮 ");
a=in.next();
if(a.equals(str1)==false){//不再继续并且没有猜出真实价格 给出真实价格
System.out.println("答案为:"+price);
}
}
else{
;
}
}
}
}
- 总结:运用equals方法判断两个字符串是否相等 equals方法判断的是两个字符串的内容是否相等 而==判断的是两个字符串所在的物理内存地址是否一致。(a.equals(b);)
万年历
- 设计思路
目的:输入某年某月可以输出这个月的日历表
输出日历表需要知道此月的天数(dayMonth)和对应的星期
天数:1.3.5.7.8.10.12这几个月永远都是31天
4.6.9.11这几个月永远都是30天
2月 当这一年是闰年是为29天 非闰年为28天
因此 需要一个方法判断闰年 (isLeap)
星期:因为知道1900.1.1是星期一 而星期是七个一循环,因此知道了从1900.1.1——xx年(xx-1)月的总天数(totaDays) 即可判断出此月的第一天为星期几
总天数可分为整年的天数和不满足整年的天数 (days)
整年的天数 闰年为366天,非闰年365天 设置循环相加即可
非整年的天数 其中闰年2月为29天,非闰年2月28天;设置循环相加可解
求出总天数后用总天数+1对7求余 余数是几即是星期几
输出格式:输出星期日——星期六,然后输出对应的日期 用‘\t’对齐 - 具体代码
/*打印万年历,输入年份和月份,输出该月的日历,已知1900年1月1日是星期一,要求:
(1)编写一个方法判断闰年
public static boolean isLeap(int year)
(2)编写一个方法判断某年某月有多少天
public static int days(int year, int month)
(3)编写一个方法计算某年某月之前距离1900年1月1日的总天数
public static int totalDays(int year, int month)
(3)编写一个输出某年某月日历的方法
public static void printCalender(int year, int month)
(4)在main方法中进行测试。
提示:判断星期几:
1+totalDays%7---值为1--7则为星期一----星期日
*/
import java.util.Scanner;
public class Canlender {
public static void main(String[] args){
Scanner in=new Scanner (System.in);
int year=in.nextInt();
int month=in.nextInt();
System.out.printf("截止到此月的天数 %d \n", days(year,month));
System.out.printf("整年的天数 %d",totalDays(year,month)-days(year,month));
System.out.printf("一共的天数 %d \n", totalDays(year,month));
printCalender(year, month);
}
public static boolean isLeap(int year){//判断是否为闰年 是闰年返回true
if((year%4==0&&year%100!=0)||year%400==0){
return true;
}
else{
return false;
}
}
public static int days(int year, int month){//求一年中截止到某月的天数 返回天数总和
int sum=0;
for(int i=1;i<month;i++){
if(i==1||i==3||i==5||i==7||i==8||i==10||i==12){
sum=sum+31;
}
else if(i==4||i==6||i==9||i==11){
sum=sum+30;
}
else if(i==2){
if((isLeap(year)==true)){
sum=sum+29;
}
else{
sum=sum+28;
}
}
}
return sum;
}
public static int totalDays(int year, int month){//求某年某月到1900年的所有天数和
int sum=0,sum1=0;
for(int i=year-1;i>=1900;i--){//如果大于1900 计算整年所包含的天数
if(isLeap(i)==true){
sum=sum+366;
}
else{
sum=sum+365;
}
}
sum1=sum+days(year,month);
return sum1;
}
public static int dayMonth(int year,int month){//输出月的天数
int daymonth = 0;
if(month==1||month==3||month==5||month==7||month==8||month==10||month==12){
daymonth=31;
}
else if(month==4||month==6||month==9||month==11){
daymonth=30;
}
else if(month==2){
if(isLeap(year)==true){
daymonth=29;
}
else{
daymonth=28;
}
}
return daymonth;
}
public static void printCalender(int year, int month){//生成日历
System.out.println("星期日\t星期一\t星期二\t星期三\t星期四\t星期五\t星期六\t");
int day;
int daymonth=dayMonth(year,month);//输出月的天数
//day=(1+totalDays(year,month)%7)%7;
day=(1+totalDays(year,month))%7;
for(int i=0;i<day;i++){//星期1需要
System.out.printf("\t");
}
for(int i=1;i<=daymonth;i++){
System.out.printf("%d\t",i);
//flag++;
if((i+day)%7==0){
System.out.printf("\n");
}
}
}
}
- 总结 运用\t来进行对齐操作
评分系统
- 设计思路
五名选手 十名裁判 设置两个数组 一个存储最后的成绩a 一个存储裁判给出的成绩b
输入成绩 进行排序 将排好序的数组中的值从第二个加到倒数第二个 以达到去掉最高分和最低分的目的
求和 算出平均数赋给数组a
对数组a进行排序 输出数组a - 具体代码
import java.util.Scanner;
import java.util.Arrays;
public class Output {
public static void main(String[] args){
Scanner in=new Scanner(System.in);
int[] b;
float[] a;
a=new float[5];
b=new int[10];
for(int i=0;i<5;i++){
System.out.println("输入第 "+(i+1)+"位的成绩");
for(int j=0;j<10;j++){
b[j]=in.nextInt();
}
Arrays.sort(b);//升序排列
a[i]=average(b);
}
Arrays.sort(a);
for(int j=4;j>=0;j--){
System.out.printf("%.2f ",a[j]);
}
}
public static float average(int[] score){//计算平均值
int sum=0;
for(int k=1;k<9;k++){//去掉最高值和最低值进行求和
sum=score[k]+sum;
}
return (sum/8.00f);
}
}
- 总结 对数组进行排序的调用方法 Arrays.sort(a);
代码托管
《Java技术》第一次作业——Java语言基础的更多相关文章
- Java技术 第一次作业
(一)学习总结 1.在java中通过Scanner类完成控制台的输入,查阅JDK帮助文档,Scanner类实现基本数据输入的方法是什么? 代码开头加一句 Import java.util; 构建Sca ...
- 2017《java技术预备作业》
2017<java技术预备作业> 1.阅读邹欣老师的博客,谈谈你期望的师生关系是什么样的? 亦师亦友,很多人这样说,确实,倘若师生之间如果中间有些隔阂最终吃亏的始终是学生.我认为师生之间应 ...
- 1903021121-刘明伟-java十一周作业-java面向对象编程
项目 内容 课程班级博客链接 19级信计班(本) 作业要求链接 第十一周作业 博客名称 1903021121-刘明伟-java十一周作业-java面向对象 要求 每道题要有题目,代码(使用插入代码,不 ...
- 2008技术内幕:T-SQL语言基础
2008技术内幕:T-SQL语言基础 单表查询摘记 这里的摘抄来自<Microsoft SQL Server 2008技术内幕:T-SQL语言基础>,书中用到的案例数据库是这个 TSQLF ...
- 2008技术内幕:T-SQL语言基础 单表查询摘记
这里的摘抄来自<Microsoft SQL Server 2008技术内幕:T-SQL语言基础>,书中用到的案例数据库是这个 TSQLFundamentals2008 ,官网给出的连接是这 ...
- 2008技术内幕:T-SQL语言基础 联接查询摘记
续 2008技术内幕:T-SQL语言基础 单表查询摘记 第三章 联接查询 Microsoft SQL Server 2008 支持四种表运算符 join(ANSI标准).apply(T-SQL扩展). ...
- Java第一次作业——Java语言基础
<Java技术>第一次作业 学习总结 1.Scanner类实现基本数据输入方法 Scanner input=new Scanner(System.in); int num = input. ...
- (转)如何学习Java技术?谈Java学习之路
51CTO编者注:这篇文章已经是有数年“网龄”的老文,不过在今天看来仍然经典.如何学习Java?本篇文章可以说也是面对编程初学者的一篇指导文章,其中对于如何学习Java的步骤的介绍,很多也适用于开发领 ...
- 2017《JAVA技术预备作业》 1502 陈明宇
1.阅读邹欣老师的博客,谈谈你期望的师生关系是什么样的? 我期望的师生关系应该是亦师亦友的关系,美丽的校园是我们学生居住生活最久的地方而老师则是和我们接触最为密切的人.在课堂上,老师是辛勤的园丁,向我 ...
随机推荐
- prop attr 到底哪里不一样?
好吧 首先承认错误 说好的每天进行一次只是总结 但是我没坚持住 准确的来说 我并没有每天会学到了东西 但是 我一直在持续努力着 以后应该不会每天都写 但是自己觉得有用的 或者想加强记忆的 可 ...
- B+树介绍
B+树 B+树和二叉树.平衡二叉树一样,都是经典的数据结构.B+树由B树和索引顺序访问方法(ISAM,是不是很熟悉?对,这也是MyISAM引擎最初参考的数据结构)演化而来,但是在实际使用过程中几乎已经 ...
- JavaScript 轮播图实例
HTML代码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <t ...
- PHP模式设计之单例模式、工厂模式、注册树模式、适配器模式、观察者模式
php模式设计之单例模式 什么是单例模式? 单例模式是指在整个应用中只有一个实例对象的设计模式 为什么要用单例模式? php经常要链接数据库,如果在一个项目中频繁建立连接数据库,会造成服务器资源的很大 ...
- 阿里云API网关(3)快速入门(调用 API)
网关指南: https://help.aliyun.com/document_detail/29487.html?spm=5176.doc48835.6.550.23Oqbl 网关控制台: https ...
- Spring Security 入门(3-11)Spring Security 的使用-自定义登录验证和回调地址
配置文件 security-ns.xml <?xml version="1.0" encoding="UTF-8"?> <beans xmln ...
- Python入门之函数的嵌套/名称空间/作用域/函数对象/闭包函数
本篇目录: 一.函数嵌套 二.函数名称空间与作用域 三.函数对象 四.闭包函数 ============================================================ ...
- 初学Java Web(4)——Servlet学习总结
经过一段时间的学习,对于Servlet有了新的不一样的见解,在这里做一下总结,将近来学习到的知识总结一下. Servlet 的请求流程 浏览器发出请求:http://localhost:80/xxx1 ...
- c语言清屏、等待、随机函数
清屏函数 #include<conio.h> system("CLS");或system(cls); 等待函数 #include<windows.h> S ...
- POJ-3641 Pseudoprime numbers---快速幂
题目链接: https://vjudge.net/problem/POJ-3641 题目大意: 问p是不是伪素数.伪素数条件:①p不是素数.② ap = a (mod p). 思路: 直接快速幂模板+ ...