一、回文数判断
1.数学方法
通过获取所输入整数的各个位数上的值来判断是否为回文数。
a.代码如下:
import java.util.Scanner;
public class Test {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
//从键盘接收int类型的回文数
System.out.print("请输入回文数:");
int num = input.nextInt();
//通过int封装类Integer的toString方法将输入整数强制转换为String类型并获取长度
//长度即为整数的位数
int len = Integer.toString(num).length();
//记录回文数的中间位置
int mid = len / 2;
//通过整数数组存储回文数每个位数上的数值
int[] arr = new int[len];
//回文数每位的位数 - 1,从最高位len开始
int max = len - 1;
//通过循环获取每个位数上的值
for (int i = 0; i < len; i++) {
if(i == 0) {//当获取最高位时,直接除以10的max次方
arr[i] = (int) (num / Math.pow(10, max--));
}else {//获取其他位时,需要得到除以10的max次方后,再模10获取目标位
arr[i] = (int) (num / Math.pow(10, max--) % 10);
}
}
//通过循环判断num是否为回文数
//不需要判断len次,只需要判断mid次,即回文数位数个数的中间值
for (int i = 0; i < mid; i++) {
if(arr[i] != arr[--len]) {//如果出现非回文数的情况,则打印不是回文数,并退出程序
System.out.println(num + "不是回文数!");
return;
}
}
//如果结束for循环后没有错误,则打印是回文数
System.out.println(num + "是回文数!");
}
上述代码中,先通过强制转换类型转换为String类型,并通过String类型的length()方法获取了整数长度,即位数个数,再通过数组获取各个位数上的值,最后进行判断。
其中,输入类型为int类型,需要注意输出长度,否则会报错。
除了利用前置转换为String类型获取长度外,还可以通过递归获取位数个数,代码如下:
public int length(Integer num){
if (num < 10){
return 1;
}else {
return 1 + length(num/ 10);
}
}
b.运行结果如下:
输入非回文数时:
输入偶数位数的回文数时:
输入奇数位数的回文数时:
2.字符串方法
直接通过String类型的charAt()判断是否为回文数。
a.代码如下:
import java.util.Scanner;
public class Test4 {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
//从键盘接收String类型的回文数
System.out.print("请输入回文数:");
String num = input.next();
//回文数长度
int len = num.length();
//回文数最后一位的位置
int max = len - 1;
//回文数中间位数的位置
int mid = len / 2;
for (int i = 0; i < mid; i++) {
if(num.charAt(max--) != num.charAt(i)) {
System.out.println(num + "不是回文数!");
return;
}
}
System.out.println(num + "是回文数!");
}
}
当输入类型为int类型时,可以通过强制转换类型,在获取长度前可以加上如下代码:
//从键盘接收String类型的回文数
System.out.print("请输入回文数:");
// String num = input.next();
int n = input.nextInt();
String num = Integer.toString(n);
b.运行结果如下:
二、获取成绩评级
1.使用if...else...语句
a.代码如下:
import java.util.Scanner;
public class Test2 {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
System.out.print("请输入分数:");
int grade = input.nextInt();
//当输入分数不合理时,打印输入错误,并直接退出程序
if(grade > 100 || grade < 0) {
System.out.println("输入错误!");
return;
}
//通过多分支语句,获得评级
if(grade >= 90 ) {
System.out.println("优秀");
}else if(grade >= 80 && grade < 90) {
System.out.println("良好");
}else if(grade >= 70 && grade < 80){
System.out.println("中等");
}else if(grade >= 60 && grade < 70) {
System.out.println("及格");
}else {
System.out.println("不及格");
}
}
}
b.运行结果如下:
2.使用switch条件语句
不同于if...else语句,switch条件语句控制的表达式类型只能是byte、short、char、int、enum枚举以及String类型,而不能是boolean类型。所以只能将分数先除以10获取十位上的数值再进行比对(当分数为100时,比对的值为10)。
a.代码如下:
import java.util.Scanner;
public class Test3 {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
System.out.print("请输入分数:");
int grade = input.nextInt();
//当输入分数不合理时,打印输入错误,并直接退出程序
if(grade > 100 || grade < 0) {
System.out.println("输入错误!");
return;
}
//获取grade十位上的值(100分则为10)
int n = grade / 10;
switch (n) {
case 10:
case 9: System.out.println("优秀!");break;//当n等于9或者10时,输出并跳出
case 8:System.out.println("良好!");break;
case 7:System.out.println("中等!");break;
case 6:System.out.println("及格!");break;
default:
System.out.println("不及格!");break;//都不满足时,输出并跳出
}
}
}
b.运行结果如下:
三、找出100-999中所有的水仙花数
a.代码如下:
public class Test5 {
public static void main(String[] args) {
for (int i = 100; i <= 999; i++) {
int a = i / 100;
int b = i / 10 % 10;
int c = i % 10;
if((a * a * a + b * b * b + c * c * c) == i) {
System.out.println(i);
}
}
}
}
b.运行结果如下:
四、打印等腰三角形
a.代码如下:
import java.util.Scanner;
public class Test6 {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
System.out.print("请输入等腰三角形的层数:");
int n = input.nextInt();
int k = 1;//每层的“*”数量
for (int i = 0; i < n; i++) {
for (int j = 1; j < n - i; j++) {
System.out.print(" ");
}
for (int j = 0; j < k; j++) {
System.out.print("*");
}
k = k + 2;
System.out.println("");
}
}
}
从键盘获取等腰三角形的层数后,就可以进行逐层打印。定义一个初值为1的层数变量k,从第二层开始,每层比上一层多两个”*“号,而”*“在前每层比上一层少一个空格,当打印第一层时,需要打印n - 1个空格及k个“*”号,第二层时,需要打印n - 2个空格及k + 2个“*”号,以此类推。由此可以知,每层打印完后需要k = k + 2,用来控制每层”*“的数量,在打印”*“之前,还需要先打印n-i即总层数减去当前层数数量的空格。