进制转换问题
1.把一个十进制转换为八进制
解题思路:
十进制转为其他数的方式就是整除取余数的方法。
每次循环整除 8 取余数,直到除到0为止
public static String toOctString(int num) {
//保存余数
String str = "0";
do {
int mod = num%8;//取出余数
str = mod + str;//拼接余数
//修改原值 整除
num = num/8;
}while(num!=0);
return str;
}
12.把一个十进制数转为二进制
思路:二进制即为逢 2 进 1。只有 0 和1。所以可以每次整除2,取出余数,逆序拼接成字符串。直到被整除到 0 为止。最后字符串中结果即为转换后的结果。
public static String toOctString(int num) {
//保存余数
String str = "";
do {
int mod = num%8;//取出余数
str = mod + str;//拼接余数
//修改原值 整除
num = num/8;
}while(num!=0);
return "0"+str;
}
3.把一个十进制数转为十六进制
思路:
基本和上面转换思想相同,但是十六进制和其他二进制八进制不同之处就是多出了 ABCDEF六个字符。
定义一个数组序列,使用下标和字符做出对应映射。这样即可巧妙的解决对应的判断问题。
否则,写很多个 if 判断就太繁琐了
public static String toHexString(int num) {
char[] ch = {'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
//保存余数
String str = "";
do {
int mod = num%16;//取出余数
str = ch[mod] + str;//拼接余数
//修改原值 整除
num = num/16;
}while(num!=0);
return "0x"+str;
}
日期问题
1.输入年份、月份、日期,打印出当前月份的日历表
思路关键点:本题的关键点就是需要控制换行和每月天数问题
1.先设置当月 1 日,然后计算出 1 日是星期几,这样可以确定 1号在周几的开始位置
2.控制每周日换行或每7天换行,但是注意第一周需要调整开始数
public class HomeWork {
private static Scanner sc = new Scanner(System.in);
public static void main(String[] args) {
System.out.println("请输入年份:");
int year = sc.nextInt();
System.out.println("请输入月份:");
int month = sc.nextInt();
System.out.println("请输入日期:");
int date = sc.nextInt();
Calendar cal = Calendar.getInstance();
//设置年份
cal.set(Calendar.YEAR, year);
//设置月份
cal.set(Calendar.MONTH, month-1); //注意***********
//设置日期 注意:先设置日期 为1日。因为获取月第一天为周几?
cal.set(Calendar.DATE, 1);
//获取1日 周几
int week = cal.get(Calendar.DAY_OF_WEEK);
//打印星期
String header = "星期日\t星期一\t星期二\t星期三\t星期四\t星期五\t星期六\t";
System.out.println(header);
//空格数
for (int i = 0; i < week-1; i++) {
System.out.print("\t");
}
//当月总天数
int days = cal.getActualMaximum(Calendar.DAY_OF_MONTH);
//开始打印日期
for (int i = 1; i <= days; i++) {
if(i==date) {
System.out.print("["+i+"]\t");
}else {
System.out.print(i+"\t");
}
//判断是否需要换行
if((i+week-1) % 7==0) { //不能直接使用i ,需要使用空格数 修正
System.out.println();
}
}
}
}
2.switch:分别输入年月日,计算出当天是年中第几天?
思路:本题主要限制的实现方式只能使用switch。
考点 主要是如何能巧妙的使用break,这里主要是在case 月份,要反着来写即可
/**
* switch:分别输入年月日,计算出当天是年中第几天?
*/
public static void daysOfYear() {
int year = 2019;
int month = 3;
int date = 12;
int days = 0;
switch (month) {
case 12:
days += 30; //11月份的天数
case 11:
days += 31; //上个月10月份的天数
case 10:
days += 30; //上个月9月份的天数
case 9:
days += 31;
case 8:
days += 31;
case 7:
days += 30;
case 6:
days += 31;
case 5:
days += 30;
case 4:
days += 31;
case 3:
days += 28;
case 2:
days += 31;
case 1:
days += date;//1月份不需要累加其他月份天数
default:
break;
}
//判断闰年 能被4整除但不能被100整除 或者 能被400整除
if((year%4==0&&year%100!=0)||year%400==0) {
days++;
}
System.out.println(year+"年"+month+"月"+date+"日是当年中的第"+days+"天");
}
乘法表问题
1.嵌套循环实现打印九九乘法表
思路:嵌套循环。主要控制内层循环条件。
每行的列数正好为当前的行号。所以可以 j<=i 控制列数
第一行:一列
第二行:两列
…
所以列数正好为行号。
/**
* 九九乘法表
* 思路:嵌套循环。主要控制内层循环条件。
* 每行的列数正好为当前的行号。所以可以 j<=i 控制列数
*/
public static void cheng() {
for (int i = 1; i <= 9; i++) {
for (int j = 1; j <= i; j++) {
System.out.print(i+"*"+j+"="+(i*j)+"\t");
}
System.out.println();
}
}
2.使用单层循环实现九九乘法表
关键思路:
在一层循环中使用了两个条件。当没达到 j==i 时 阻止了i++;
从而实现了列数控制的效果
public static void main(String[] args) {
// 循环控制实现输出九行
for (int i = 1, j = 1; i < 10; j++) {
System.out.print(i + "*" + j + "=" + (i * j) + "\t");
//当行数等于列数时换行,但是列数重0开始,行数加一
if (j == i) {
System.out.println();
j = 0;
i++;
}
}
}