基本语法2-流程控制_练习&面试题

51 篇文章 0 订阅
30 篇文章 3 订阅

写出结果。
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");
        
    }
}


//没有结果。
-------------------------------------------------------
switch是否能作用在byte上,是否能作用在long上,是否能作用在String上
答:switch(expr1)中,expr1是一个整数表达式。因此传递给 switch 和 case 语句的参数应该是
int、 short、 char 或者 byte。long不能作用于swtich.JDK1.7新加入了String类型。

-------------------------------------------------------
从键盘分别输入年、月、日,判断这一天是当年的第几天。
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
                + "天");
    }
}
-------------------------------------------------------
写出结果。
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、 输出从1到100之间所有的整数;
2、 输出从1到100之间所有的奇数;
3、 输出从1到100之间所有不能被3整除的数;并输出这些整数的和

-------------------------------------------------------
1)输入长和宽,输出长方形,如:输入4和3, 将输出如下图形
####
####
####
2)输入高度,输出直角三角形。如:输入4, 将输出如下图形
#
##
###
####
3)输入高度,输出倒直角三角形。如:输入4, 将输出如下图形
####
###
##
#

-------------------------------------------------------
打印九九乘法表

-------------------------------------------------------
输入两个正整数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的倍数的自然数出现的次数?

[answer1]
public static void main(String[] args) {
    int count = 0;
    for(int x=1; x<=100; x++){            
        if(x%6==0)
            //System.out.println("x="+x);
            count++;
    }
    System.out.println("count="+count);

    /*
    计数器思想。
    通过一个变量记录住数据的状态变化。
    */
}
[answer2]

-------------------------------------------------------
求调和级数中从第多少项开始值大于10,调和级数的第n项形式为:1+1/2+1/3+…+1/n
(略)
-------------------------------------------------------
3000米长的绳子,每天减一半。问多少天这个绳子会小于5米?不考虑小数。
[answer]
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)若某个年份能被4整除但不能被100整除,则是闰年。
      (2)若某个年份能被400整除,则也是闰年。

if((year % 4 ==0 && year % 100 != 0) || year % 400 == 0){}
-------------------------------------------------------
利用程序输出如下图形:
   *
   * * *
   * * * * *
   * * * * * * *
   * * * * *
   * * *
   *
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();

}
-------------------------------------------------------
要求用户输入两个数a和b,如果a能被b整除或者a加b大于1000,则输出a;否则输出b。

-------------------------------------------------------
一个数如果恰好等于它的因子之和,这个数就称为"完数"。(因子:除去这个数本身正的约数)
例如6=1+2+3.编程 找出1000以内的所有完数
public class WanShu {
    static int count;
    public static void main(String[] args) {
        int factor=0;
        for (int i = 1; i <= 1000; i++) {
            for (int j = 1; j < i; j++) {
                if(i%j==0)
                    factor+=j;
            } 
            if(factor == i){
                System.out.println(i);
                count++;
            }
            factor=0;
        }
        System.out.println("1-1000之间的完数个数为:"+count);
    }
}

-------------------------------------------------------
写一个程序,找出4位数的所有吸血鬼的数字
例如:1260=21*60
      1827=21*87

public class Test2 {
    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);
            }
        }
    }
}

-------------------------------------------------------
在JAVA中,如何跳出当前的多重嵌套循环?
答:用break; return 方法。break 标签名

-------------------------------------------------------

-------------------------------------------------------

-------------------------------------------------------

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值