day04 Java基础语法 (下)

笔记Notes要点

  • switch-case语句注意

  • switch-case题目(switchTest5)

  • 循环执行顺序

  • if-else 实现3个整数排序

  • String字符串比较

  • 循环四要素

  • 打印九九乘法表

  • 特殊关键字continue、break

  • switch(表达式) 表达式里仅支持 byte、short、char、int、枚举、String(jdk1.7后)

switch(表达式){

case 常量1:

执行语句1;

break;

case 常量2:

执行语句2;

break;

......

default:

执行语句n;

break;

}

  • case 后面只能跟常量,default是可选的。如果都没有匹配成功则执行default中的执行语句。default的位置是灵活的。

  • switch-case和if-else可以替换,switch-case效率高一些

/*

从键盘分别输入年、月、日,判断这一天是当年的第几天

注:判断一年是否是闰年的标准:

1)可以被4整除,但不可被100整除

2)可以被400整除

*/

import java.util.Scanner;

public class SwitchTest5{

public static void main(String[] args){

//1.读取数据

Scanner sc = new Scanner(System.in);

System.out.println("请输入年份");

int year = sc.nextInt();

System.out.println("请输入月份");

int month = sc.nextInt();

System.out.println("请输入日期");

int day = sc.nextInt();

int sumDay = 0; //用来统计当年的总天数

//2.统计天数

switch(month){

case 4:

sumDay += 31;

case 3:

//判断当年是否是闰年

if((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0)){

sumDay += 29;

}else{

sumDay += 28;

}

case 2:

sumDay  += 31;

case 1:

sumDay += day;

}

//3.输出

System.out.println(year + "年" + month + "月" + day + "日是当年的第" + sumDay + "天");

}

}

/*

编写程序:由键盘输入三个整数分别存入变量num1、num2、num3,

对它们进行排序(使用 if-else if-else),并且从小到大输出。

*/

import java.util.Scanner;

public class IfTest

{

public static void main(String[] args){

Scanner sc = new Scanner(System.in);

System.out.println("请输入三个数字");

int num1,num2,num3;

num1 = sc.nextInt();

num2 = sc.nextInt();

num3 = sc.nextInt();

if(num1>num2){

if(num3>num1){//num3最大

System.out.println("小到大:"+ num2 +" "+ num1 +" "+ num3);

}else if(num3<num2){//num3最小

System.out.print("小到大:"+ num3 + " " + num2 + " " + num1);

}else{

System.out.println("小到大:"+ num2 + " " + num3 + " " + num1);

}

}else{//num1<num2

if(num3>num2){//num3最大

System.out.println("小到大:"+ num1 + " "+ num2 + " "+ num3);

}else if(num3<num1){//num2最大

System.out.println("小到大:"+ num3 + " " + num1 + " " + num2);

}else{

System.out.println("小到大:"+ num1 + " " + num3 + " " + num2);

}

}

}

}

    • String字符串比较

String str = new String("帅");

//判断帅不帅

System.out.println("帅" ==  str); //这样不能比字符串的内容

boolean handsome = "帅".equals(str); //比较的是字符串的内容 - 如果内容相同返回true否则返回false

    • switch使用小技巧

对学生成绩大于60分的,输出“合格”。低于60分的,输出“不合格”

switch(score / 60){

case 0:

System.out.println("不合格");

break;

case 1:

System.out.println("合格");

break;

  • 编写程序:输入月,日,输出第几天

/*

4. 编写程序:从键盘上输入2019年的“month”和“day”,要求通过程序输出输入的日期为2019年的第几天。

*/

import java.util.Scanner;

public class SwitchTest4{

public static void main(String[] args){

//1.读取数据

Scanner sc = new Scanner(System.in);

System.out.println("请输入月份");

int month = sc.nextInt();

System.out.println("请输入日期");

int day = sc.nextInt();

int sumDay = 0; //用来统计当年的总天数

//2.统计天数

switch(month){

/*

case 1:

sumDay = day;

break;

case 2:

sumDay = day + 31;

break;

case 3:

sumDay = day + 31 + 28;

break;

case 4:

sumDay = day + 31 + 28 + 31;

break;

*/

case 4:

sumDay += 31;

case 3:

sumDay += 28; //赋值和+=完全不一样。sumDay += 28 : 除了sumDay原来的天数再额外加上28

case 2:

sumDay  += 31; // sumDay = sumDay + 31

case 1:

sumDay += day;

}

//3.输出

System.out.println("2019年" + month + "月" + day + "日是当年的第" + sumDay + "天");

}

}

  • 编写程序:输入年,月,日,输出第几天

/*

从键盘分别输入年、月、日,判断这一天是当年的第几天

注:判断一年是否是闰年的标准:

1)可以被4整除,但不可被100整除

2)可以被400整除

*/

import java.util.Scanner;

public class SwitchTest4

{

public static void main(String[] args){

Scanner sc = new Scanner(System.in);

System.out.println("请输入年份:");

int year = sc.nextInt();

System.out.println("请输入月份:");

int month = sc.nextInt();

System.out.println("请输入天数:");

int day = sc.nextInt();

int sumDay = 0;

switch(month){

case 12:

sumDay += 30;

case 11:

sumDay += 31;

case 10:

sumDay += 30;

case 9:

sumDay += 31;

case 8:

sumDay += 31;

case 7:

sumDay += 30;

case 6:

sumDay += 31;

case 5:

sumDay += 30;

case 4:

sumDay += 31;

case 3:

// 28或 29

if((year%4==0&&year%100!=0)||year % 400 ==0){//闰年

sumDay += 29;

}else{

sumDay += 28;

}

case 2:

sumDay += 31;

case 1:

sumDay += day;

break;

}

System.out.println(year+"年" + month + "月" + day + "日是当年的第" + sumDay + "天");

}

}

  • 循环四要素

循环的四个部分:

1.初始化条件

2.循环条件

3.循环体

4.迭代条件

  • 打印九九乘法表

/*

1*1=1

1*2=2 2*2=4

1*3=3 2*3=6 3*3=9

打印九九乘法表

*/

public class c99

{

public static void main(String[] args){

int i,j;

for(i=1;i<=9;i++){//9行

for(j=1;j<=i;j++){

System.out.print(j + "*" +i+" = "+ i*j +" ");

}

System.out.println();

}

}

}

  • 特殊关键字continue、break

    • break用于 switch-case语句与循环结构中,表示结束当前case语句,结束循环语句

    • continue,用于 循环结构  表示结束当此循环。

    • 在嵌套循环中break结束的包含该语句的循环语句,对外层循环无作用

    • 在嵌套循环中continue跳出的是包含他的循环语句的当次循环,不跳出

  • 嵌套循环中如何使用内部循环的break结束外层循环

可以给循环命名,break + 循环名字

总结Summary

  • if-else实现三个整数排序

  • 打印九九乘法表

  • break,continue使用注意事项

Java编程基础阶段笔记 day04 Java基础语法(下)的更多相关文章

  1. Java编程思想重点笔记(Java开发必看)

    Java编程思想重点笔记(Java开发必看)   Java编程思想,Java学习必读经典,不管是初学者还是大牛都值得一读,这里总结书中的重点知识,这些知识不仅经常出现在各大知名公司的笔试面试过程中,而 ...

  2. Java编程基础阶段笔记 day01 Java语言概述

    ​目录内容 DOS命令 电脑配置 Java语言的特性 Java两种核心机制 Java语言环境搭建 第一个Java程序 注释 Java语句说明 编程风格 作业 常用的DOS命令 dir :    列出当 ...

  3. 【Java编程思想阅读笔记】Java数据存储位置

    Java数据存储位置 P46页有感 一.前置知识 栈是由系统自动分配的,Java程序员对栈没有直接的操作权限, 堆是所有线程共享的内存区域,栈 是每个线程独享的. 堆是由程序员自己申请的,在使用new ...

  4. Java编程思想学习笔记_1(Java内存和垃圾回收)

    1.Java中对象的存储数据的地方: 共有五个不同的地方可以存储数据. 1)寄存器.最快,因为位于处理器的内部,寄存器按需求分配,不能直接控制. 2)堆栈.位于通用RAM,通过堆栈指针可以从处理器那里 ...

  5. JAVA编程思想读书笔记(二)--容器

    接上篇JAVA编程思想读书笔记(一) 第八章.对象的容纳 No1: java提供了四种类型的集合类:Vector(矢量).BitSet(位集).Stack(堆栈).Hashtable(散列表) No2 ...

  6. Java编程思想总结笔记The first chapter

    总觉得书中太啰嗦,看完总结后方便日后回忆,本想偷懒网上找别人的总结,无奈找不到好的,只好自食其力,尽量总结得最好. 第一章  对象导论 看到对象导论觉得这本书 目录: 1.1 抽象过程1.2 每个对象 ...

  7. Java编程思想总结笔记Chapter 2

    本章介绍Java程序的基本组成部分,体会到Java中几乎一切都是对象. 第二章   一切都是对象 目录: 2.1 用引用操纵对象 2.2 必须由你创建所有对象 2.3 永远不需要销毁对象 2.4 创建 ...

  8. JAVA编程思想读书笔记(五)--多线程

    接上篇JAVA编程思想读书笔记(四)--对象的克隆 No1: daemon Thread(守护线程) 参考http://blog.csdn.net/pony_maggie/article/detail ...

  9. JAVA编程思想读书笔记(四)--对象的克隆

    接上篇JAVA编程思想读书笔记(三)--RTTI No1: 类的克隆 public class MyObject implements Cloneable { int i; public MyObje ...

随机推荐

  1. log4net插入access自定义字段

    1.创建表格 2.创建log4net.xml,并设置属性始终复制,关键属性 <bufferSize value="1" /> <conversionPattern ...

  2. 【前端工具】页面加载获取url param

    例如跳转进入一个页面: https://mp.csdn.net/postedit/74766644?name=catalina&flag=1 函数: function getParam(par ...

  3. Java:synchronized关键字引出的多种锁

    前言 Java 中的 synchronized关键字可以在多线程环境下用来作为线程安全的同步锁.本文不讨论 synchronized 的具体使用,而是研究下synchronized底层的锁机制,以及这 ...

  4. Ruby系列文章

    安装Ruby.多版本Ruby共存.Ruby安装慢问题 Ruby语言的一些杂项 Ruby中的常量:引号.%符号和heredoc Ruby中的数值 Ruby字符串(1):String基本用法 Ruby字符 ...

  5. 算法详解之最近公共祖先(LCA)

    若图片出锅请转至here 概念 首先是最近公共祖先的概念(什么是最近公共祖先?): 在一棵没有环的树上,每个节点肯定有其父亲节点和祖先节点,而最近公共祖先,就是两个节点在这棵树上深度最大的公共的祖先节 ...

  6. 关于char[]转换成LPCWSTR的有关问题[转]

    一.问题的原因:VS2010默认采用宽字符UNICODE编码方式,定义了Unicode,因此相关的字符串必须为unicode字符串,而非ascii字符串. LPCWSTR中的W是宽字符的意思,是UNI ...

  7. HDU 6043:Colorful Tree(树上统计所有路径总颜色数)***

    题目链接 题意 给出一棵有n个结点的树,每个结点有一个颜色,问在这棵树的所有路径中,每条路径的颜色数求和是多少. 思路 求每种颜色的贡献可以转化为总的和减去每种颜色在哪些路径上没有出现的贡献,一个颜色 ...

  8. POJ 1651:Multiplication Puzzle(区间DP)

    http://poj.org/problem?id=1651 题意:给出n个数字,每取中间一个数,就会使得权值加上中间这个数和两边的乘积,求取剩两个数最少的权值是多少. 思路:区间dp. 一开始想了挺 ...

  9. Go - 循环

    目录 概述 循环 array 循环 slice 循环 map break continue goto switch 推荐阅读 概述 前几篇文章分享了 array 数组.slice 切片.map 集合, ...

  10. java中动态代理的使用

    代理模式是常用的java设计模式,他的特征是代理类与委托类有同样的接口,代理类主要负责为委托类预处理消息.过滤消息.把消息转发给委托类,以及事后处理消息等.代理类与委托类之间通常会存在关联关系,一个代 ...