进制转换问题

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++;
			}
		}
	}