JAVA入门 常见问题总结:第二章 知识点(2)流程控制
分支结构:
-
写出结果:
class Demo{ public static void main(String[] args){ int m=0,n=3; if(m>0) if(n>2) System.out.println("A"); else System.out.println("B"); } } //answer:没有结果
-
实现对三个整数进行排序,输出时按照从小到大的顺序输出。
-
从键盘分别输入年、月、日,判断这一天是当年的第几天
public class Test { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.println("输入year:"); int year = scanner.nextInt(); System.out.println("输入month:"); int month = scanner.nextInt(); System.out.println("输入day:"); int day = scanner.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: if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0) sumDay += 29; else sumDay += 28; case 2: sumDay += 31; case 1: sumDay += day; } System.out.println(year + "年" + month + "月" + day + "日是今年的第" + sumDay + "天"); } }
-
switch是否能作用在byte上,是否能作用在long上,是否能作用在String上
答:switch(expr1)中,expr1是一个整数表达式。因此传递给 switch 和 case 语句的参数应该是
int、 short、 char 或者 byte。long不能作用于swtich.JDK1.7新加入了String类型。 -
编写程序,判断给定的某个年份是否是闰年
闰年的判断规则如下:
(1)若某个年份能被4整除但不能被100整除,则是闰年。
(2)若某个年份能被400整除,则也是闰年。if((year % 4 ==0 && year % 100 != 0) || year % 400 == 0){}
-
要求用户输入两个数a和b,如果a能被b整除或者a加b大于1000,则输出a;否则输出b。
-
编写程序,从键盘接收整数参数.如果该数为1-7,打印对应的星期值,否则打印“非法参数”。
-
使用条件结构实现,如果用户名等于字符‘青’,密码等于数字‘123’,就输出“欢迎你,青”,否则就输出“对不起,你不是青”。
提示:先声明两个变量,一个是char型的,用来存放用户名,一个是int型的,用来存放密码。 -
⭐️求ax2+bx+c=0方程的根。
a,b,c分别为函数的参数,
如果:b2-4ac>0,则有两个解;b2-4ac=0,则有一个解;b2-4ac<0,则无解;
已知:x1=(-b+sqrt(b2-4ac))/2a
X2=(-b-sqrt(b2-4ac))/2aSystem.out.println("求 ax^2 + bx + c = 0的解"); Scanner scan = new Scanner(System.in); while (true) { int a, b, c; a = b = c = 0; //或 int a=0, b=0, c=0; System.out.println("请输入a的值"); if (scan.hasNextInt()) { a = scan.nextInt(); if (a == 0) { System.out.println("此方程不是2元1次方程,解方程结束"); return; } } System.out.println("请输入b的值"); if (scan.hasNextInt()) { b = scan.nextInt(); } System.out.println("请输入c的值"); if (scan.hasNextInt()) { c = scan.nextInt(); } System.out.println("a=" + a + ", b=" + b + ", c=" + c); double result = b*b - 4 * a * c; System.out.println(result); if (result < 0) { System.out.println("此方程无解"); }else { System.out.println(Math.sqrt(result)); double x1 = (-b + Math.sqrt(result))/(2*a); System.out.println("x1 = " + x1); if (result > 0) { double x2 = (-b - Math.sqrt(result))/(2*a); System.out.println("x2 = " + x2); System.out.println("此方程有2个解"); return; } System.out.println("此方程只有一个解"); } }
-
生成13位条形码
```
Ean-13码规则:第十三位数字是前十二位数字经过计算得到的校验码。
例如:690123456789
计算其校验码的过程为:
@前十二位的奇数位和6+0+2+4+6+8=26
@前十二位的偶数位和9+1+3+5+7+9=34
@将奇数和与偶数和的三倍相加26+34*3=128
@取结果的个位数:128的个位数为8
@用10减去这个个位数10-8=2
所以校验码为2
(注:如果取结果的个位数为0,那么校验码不是为10(10-0=10),而是0)
实现方法ean13()计算验证码,输入12位条码,返回带验证码的条码。
例:输入:692223361219输出:6922233612192
```
```
//实现代码
static void test1 () {
Scanner scan = new Scanner(System.in);
String numberString;
while (true) {
System.out.println("输入12位条码");
if (scan.hasNext()) {
numberString = scan.next();
//if (number >= 10000000000L && number <= 99999999999L) {//为了让编译器直接识别较长的long型,需要直接使用"L"标明。
if (numberString.length() == 12) {
System.out.println(numberString);
break;//退出循环
}else {
System.out.println("输入位数错误");
}
}
}
int sum1 = 0;//奇数位的和
int sum2 = 0;//偶数位的和
for (int i = 0; i < 12; i++) {
char letter = numberString.charAt(i);
int iNumber = (int)letter - (int)'0';
if (i%2 == 0) {
//奇数位
sum1 += iNumber;
}else {
//偶数位
sum2 += iNumber;
}
}
int checkCode = 10 - (sum1 + sum2 * 3) % 10;
System.out.println("奇数位的和:" + sum1 + "\n偶数位的和:" + sum2 + "\n得到的校验码:" + checkCode);
//其实应该分个字符串放进数组便利
/*
* 输入12位条码
* 690123456789
690123456789
奇数位的和:26
偶数位的和:34
得到的校验码:2
输入12位条码
692223361219
692223361219
奇数位的和:15
偶数位的和:31
得到的校验码:2
* */
```
-
循环结构:
//What is the result when you compile and run the following code? public class Test{ public void method(){ for(int i = 0; i < 3; i++) { System.out.print(i); } System.out.print(i); } }
A. 0122 B. 0123 C. compile error D. none of these
答案:C
-
打印1-100之间13的倍数,使用for循环
static void test2() { for (int i = 1; i < 101; i++) { if (i % 13 == 0) { System.out.println(i); } } //共需执行100 * 100 = 10000次 for (int i = 1; i <= 101 / 13; i++) { System.out.println(13 * i); } //只需执行101/13次,远远小于第一种 //13//26//39//52//65//78//91 }
-
使用双重循环打印20 * 8的矩形,使用for循环实现
static void test3() { for (int i = 0; i < 8; i++) { String string = ""; for (int j = 0; j < 20; j++) { string = string + "*"; } System.out.println(string);//默认换行 } }
-
用for循环计算1000以内奇数的和
-
1)输入长和宽,输出长方形,如:输入4和3, 将输出如下图形
2)输入高度,输出直角三角形。如:输入4, 将输出如下图形
3)输入高度,输出倒直角三角形。如:输入4, 将输出如下图形
-
打印九九乘法表
-
3000米长的绳子,每天减一半。问多少天这个绳子会小于5米?不考虑小数。
public static void main(String[] args) { int day = 0; for (int x = 3000; x >= 5; x /= 2) { day++; } System.out.println("day=" + day); /* * 方法二: * day = 0; * for(int x=3000; x>=5; day++) { * x = x/2; * } * System.out.println(day); */ }
-
打印1-100之间13的倍数,使用continue语句
-
混合结构练习
写出结果public class Demo{ public static void main(String []args){ int i = 0, j = 5; tp: for (;;){ i++; for(;;){ if(i > j--) break tp; } } System.out.println("i = " + i + ", j = "+ j); //i=1,j=-1; } }
-
输出从1到100之间所有不能被3整除的数;并输出这些整数的和
-
输入两个正整数m和n,求其最大公约数和最小公倍数
int m = 12, n = 28; //获取m和n的较大值 int max = (m > n)? m : n; //获取m和n的较小值 int min = (m < n)? m : n; //求m和n的最大公约数 for(int i = min;i >= 1;i--){ if( m % i == 0 && n % i == 0){ System.out.println("m和n的最大公约数是:" + i); break; } } //求m和n的最小公倍数 for(int i = max;i <= m * n;i++){ if( i % m == 0 && i % n == 0){ System.out.println("m和n的最小公倍数是:" + i); break; } }
-
根据指定月份,打印该月份所属的季节
分别使用if-else if-else语句和switch-case语句:
3,4,5 春季 6,7,8 夏季 9,10,11 秋季 12, 1, 2 冬季[answer] if(x==3 || x==4 || x==5) System.out.println(x+"春季"); else if(x==6 || x==7 || x==8) System.out.println(x+"夏季"); else if(x==9 || x==10 || x==11) System.out.println(x+"秋季"); else if(x==12 || x==1 || x==2) System.out.println(x+"冬季"); else System.out.println(x+"月份不存在"); [第二种] if(x>12 || x<1) System.out.println(x+"月份不存在"); else if(x>=3 && x<=5) System.out.println(x+"春季"); else if(x>=6 && x<=8) System.out.println(x+"夏季"); else if(x>=9 && x<=11) System.out.println(x+"秋季"); else System.out.println(x+"冬季"); [第3种] public static void main(String[] args) { int x = 4; switch(x){ case 3: case 4: case 5: System.out.println(x+"春季"); break; case 6: case 7: case 8: System.out.println(x+"夏季"); break; case 9: case 10: case 11: System.out.println(x+"秋季"); break; case 12: case 1: case 2: System.out.println(x+"冬季"); break; default: System.out.println("nono"); } }
-
已知学生成绩以100分为满分,共分5个等级:A,B,C,D,E。90~100为等级A,80~89为等级B,70~79为等级C,60~69为等级D,0~59为等级E。
要求定义一个成绩变量,当成绩变化时,可直接知道该成绩对应的等级。 例如:当成绩为100时,该学生的等级时A。 class LevelDemo{ //定义一功能,通过给定分数,获取该分数对应的等级。 public static void main(String[] args){ int num = 89; if(num>=90 && num<=100) System.out.println("level = A"); else if(num>=80 && num<=89) System.out.println("level = B"); else if(num>=70 && num<=79) System.out.println("level = C"); else if(num>=60 && num<=69) System.out.println("level = D"); else System.out.println("level = E"); } }
-
1)打印1~100之间 6的倍数的个数;
2)求出1~100之间,既是3又是7的倍数的自然数出现的次数?public static void main(String[] args) { int count1 = 0,count2 = 0; for (int x = 1; x <= 100; x++) { if (x % 6 == 0){ count1++; } if(x % 3 == 0 && x % 7 == 0){ count2++; } } System.out.println("count1=" + count1); System.out.println("count2=" + count2); }
-
求调和级数中从第多少项开始和的值大于10
调和级数的第n项形式为:1+1/2+1/3+…+1/npublic static void main(String[] args) { double sum = 0.0; int i = 1; while (true) { sum += 1.0 / i; if (sum > 10) { break; } i++; } System.out.println(i); }
-
打印如下的图形
* * * * * * * * * * * * * * * * * * * * * * * * * for (int i = 0; i < 7; i++) { if (i < 4) { for (int j = 0; j < 2 * i + 1; j++) { System.out.print("* "); } System.out.println(); } else { for (int k = 0; k < 13 - 2 * i; k++) { System.out.print("* "); } System.out.println(); } }
-
【拓展】打印如下的图形
* * * * * * * * * * * * * * * * * * * * * * * * * // 上半部分 for (int i = 0; i < 5; i++) { // 输出“-” for (int j = 0; j < 4 - i; j++) { System.out.print(" "); } // 输出“* ” for (int k = 0; k < i + 1; k++) { System.out.print("* "); } System.out.println(); } // 下半部分 for (int i = 0; i < 4; i++) { for (int j = 0; j < i + 1; j++) { System.out.print(" "); } for (int k = 0; k < 4 - i; k++) { System.out.print("* "); } System.out.println(); } //解法2 static void test6() { Scanner scan = new Scanner(System.in); System.out.println("请输入菱形的规模,仅限与奇数"); int startsCount = 0; if (scan.hasNextInt()) { startsCount = scan.nextInt(); } if (startsCount % 2 == 0) { System.out.println("非奇数"); return; } //打印目标 int a = startsCount / 2 + 1; for (int i = 0; i < startsCount; i++) { String currentString = ""; if (i < a) {//上部 for (int j = 0; j < startsCount / 2 - i; j++) { currentString += " "; } for (int j = 0; j <= i; j++) { currentString += "* "; } } else {//下部 /* * 中间星星的总数 = 总数/2 +1; * 空格数 = 中间星星数 - (行数相对于中间的相对值); * */ for (int j = 0; j < i-a+1; j++) { currentString += " "; } for (int j = a - (i-a+1); j > 0; j--) { currentString += "* "; } } System.out.println(currentString); } }
-
拓展:打印如下的图形
********** **** **** *** *** ** ** * * ** ** *** *** **** **** ********** //code static void test7() { int rows = 9; for (int i = 0; i < rows; i++) { String starsString = ""; if (i <= rows/2) { //上部 //分左右 for (int j = 0; j < rows+1; j++) { //总数 rows+1 //星星数 2*i if (j >= (rows+1)/2-i && j< (rows+1)/2+i) { starsString += " "; }else { starsString += "*"; } } } else { //下部 for (int j = 0; j < rows+1; j++) { if (j >= (i-rows/2)+1 && j < (rows+1)-((i-rows/2)+1)) { starsString += " "; } else { starsString += "*"; } } } System.out.println(starsString); } }
-
编写程序,打印100-200之间的质数
for (int i = 100; i <= 200; i++) { int count = 0;//记录当前i的因数个数 for (int j = 1; j <= i; j++) { if (i % j == 0) { count ++; if (count > 2) { continue; } } } if (count == 2) { System.out.println("素数" + i); } }
-
一个数如果恰好等于它的因子之和,这个数就称为"完数"
(因子:除去这个数本身正的约数)
例如6=1+2+3.编程 找出1000以内的所有完数public class WanShu { //方法2 自写 for (int i = 1; i <= 1000; i++) { int sum = 0; for (int j = 1; j < i; j++) { if (i % j == 0) { sum += j; } } if (sum == i) { System.out.println(i); } } //方法1 Demo static int count; public static void main(String[] args) { for (int i = 1; i <= 1000; i++) { int factor = 0; for (int j = 1; j < i; j++) { if (i % j == 0) factor += j; } if (factor == i) { System.out.println(i); count++; } } System.out.println("1-1000之间的完数个数为:" + count); } }
-
⭐️(数组暂时没学)写一个程序,找出4位数的所有吸血鬼的数字
例如:1260=21*60
1827=21*87public class Test1 { public static void main(String[] args) { for (int num = 1001; num < 10000; num++) { math(num); } } public static void math(int num) { int[] temp1 = new int[2]; int[] temp2 = new int[2]; int a = num / 1000; int b = num / 100 % 10; int c = num / 10 % 10; int d = num % 10; int[] data = { a, b, c, d }; for (int i = 0; i < data.length; i++) { for (int j = 0; j < data.length; j++) { if (i == j) { continue; } temp1[0] = data[i]; temp1[1] = data[j]; for (int m = 0; m < data.length; m++) { if (m != i && m != j) { temp2[0] = data[m]; for (int n = 0; n < data.length; n++) { if (n != i && n != j && n != m) { temp2[1] = data[n]; multi(data, temp1, temp2); } } } } } } } public static int toInt(int[] temp) { int m = 0; int[] temp1 = new int[temp.length]; for (int i = 0; i < temp.length; i++) { temp1[i] = temp[i] * (int) Math.pow(10, temp.length - 1 - i); } for (int i = 0; i < temp1.length; i++) { m += temp1[i]; } return m; } public static void multi(int[] temp, int[] temp1, int[] temp2) { int i = toInt(temp1); int j = toInt(temp2); int k = toInt(temp); if (k == i * j) { System.out.println(k + "=" + i + "*" + j); } } }
-
输出所有的水仙花数。所谓水仙花数是指一个3位数,其各个位上数字立方和等于其本身。
例如: 153 = 1*1*1 + 3*3*3 + 5*5*5 class ShuiXianHua { public static void main(String[] args) { for (int i = 100; i < 1000; i++) {// 实现所有的三位数的一个遍历 int j1 = 0; int j2 = 0; int j3 = 0; j1 = i / 100;// 百位 j2 = (i - 100 * j1) / 10;// 十位 j3 = i - 100 * j1 - 10 * j2;// 个位 if (i == j1 * j1 * j1 + j2 * j2 * j2 + j3 * j3 * j3) { System.out.println("此数值为满足条件的水仙花数:" + i); } } } }
-
山上有一口缸可以装50升水,现在有15升水。老和尚叫小和尚下山挑水,每次可以挑5升。问:小和尚要挑几次水才可以把水缸挑满?通过编程解决这个问题。
提示:
(1) 用整型变量water表示水缸里的水“int water = 15;”。
(2) 用整型变量l表示小和尚下山挑水的次数“int l = 0;”。
(3) 分析循环条件(水少于50升),循环操作(水增加5升,挑水次数增加1)。
(4) 套用while循环(或do-while循环)写出代码。 -
实现判断一个4位整数,统计出此整数里面包含多少个偶数,多少个奇数的功能
-
开发一款软件,根据公式(身高-108)*2=体重,可以有10斤左右的浮动。来观察测试者体重是否合适。
-
有3个整数,给出提示信息:
能否创建三角形;两边之和大于第三边 三个条件都要写
如果能构建三角形,提示是直角三角形还是等边三角形等腰三角形还是普通三角形;
最后输出三角形面积; -
在JAVA中,如何跳出当前的多重嵌套循环?
答:用break; return 方法。