学习总结

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);

代码托管



最新文章

  1. Apache日志分析
  2. 示例篇-购物车的简单示例和自定义JS
  3. 【翻译】西川善司「实验做出的游戏图形」「GUILTY GEAR Xrd -SIGN-」中实现的「纯卡通动画的实时3D图形」的秘密,前篇(2)
  4. 开篇呀,恭喜恭喜,是个好开头-----关于sort()排序
  5. JAVA 可视化分析工具 第12节
  6. 放开chrome,微度新标签页 删除
  7. windows container (docker) 容器资料笔记
  8. Pandas系列(四)-文本数据处理
  9. kibana get 查询失效
  10. Java中用字符串常量赋值和使用new构造String对象的区别
  11. iOS中 支付宝钱包具体解释/第三方支付 韩俊强的博客
  12. Linux服务器定位CPU高占用率代码位置经历
  13. 人工智能时代,是时候学点Python了!
  14. Linux查看修改时间、时区
  15. 允许Ubuntu系统下Mysql数据库远程连接
  16. 大数据入门第十四天——Hbase详解(三)hbase基本原理与MR操作Hbase
  17. MLLib实践Naive Bayes
  18. JVM(三)调优工具
  19. 使用exe4j将jar包导出为exe
  20. EasyUI中combobox的使用方法和一个代码实例

热门文章

  1. excel2003和excel2007文件的创建和读取
  2. js 点击 返回顶部 动画
  3. python time、datetime、random、os、sys模块
  4. openssl几个加密算法使用介绍
  5. Lumen框架搭建指南
  6. python JavaScript
  7. ubuntu16.04安装jdk1.8
  8. CSS禁止输入之readonly VS disable
  9. selenium 设置代理的话,可以使用这种方式,代码是我刚才测试过的,亲测可用
  10. codevs 1054 电梯