java练习--星期计算+回文+评委评分

  1. 已知今天是星期六,请问(20的22次方)天后是星期几?

注:用数字1到7表示星期一到星期日

import java.math.BigInteger;
public class java_星期计算 {
    public static void main(String[] args) {

        BigInteger bigInteger = BigInteger.valueOf(20).pow(22).mod(BigInteger.valueOf(7));
        System.out.println(bigInteger.intValue());
        int result = (bigInteger.intValue() + 6) % 7;
        System.out.println(result == 0 ? "星期天" : "星期"+result );
    }
}

有些正整数的形状像“一座山”,比如123565321、145541,它们左右对称(回文),且数位上的数字先单调不减,后单调不增

  1. 区间[2022,2022222022]中有多少个数的形状像一座“山”
public class java_回文 {
    public static void main(String[] args) {
        int count = 0;
        for(int i = 2022; i<= 2022222022; i++){
            if(method(i)){
                count++;
            }
        }
        System.out.println(count);
    }
    public static boolean method(int num){
        char[] chars = (""+num).toCharArray();
        int start = 0;
        int end = chars.length-1;
        while(start < end){
            if (chars[start] != chars[end] || chars[start] > chars[start + 1]){
                return false;
            }
            start++;
            end--;
        }
        return true;
    }
}
  1. 在唱歌比赛中,有6名评委给选手打分,分数的范围是0-100之间的整数。

注:选手的最后得分为:去掉最高分,最低分后4个评委的平均分,请完成上述过程并计算选手的得分

import java.util.Scanner;
public class java_评分 {
    public static void main(String[] args) {
    // 定义一个数组用来存储6名评委的打分(0-100)
        int[] scoreArr = new int[6];
        Scanner scanner = new Scanner(System.in);
        for (int i = 0; i<scoreArr.length; ){
            System.out.println("请第"+(i+1)+"位评委打分");
            int score = scanner.nextInt();
    // 评委分数在[0,100]范围内
            if (score<=100 && score>=0){
                scoreArr[i] = score;
                i++;
            }
        }
        int max = getMax(scoreArr);
        int min = getMin(scoreArr);
        int sum = getSum(scoreArr);
        int avg = (sum-max-min) / (scoreArr.length-2);
        System.out.println("该选手的平均分数为:"+avg);
    }
    //评委打分总和
    public static int getSum(int[] scoreArr){
        int sum = 0;
        for(int i=0; i<scoreArr.length; i++){
            sum += scoreArr[i];
        }
        return sum;
    }
    //评委打分最大值
    public static int getMax(int[] scoreArr){
        int max = scoreArr[0];
        for(int i=0; i<scoreArr.length; i++){
            if(scoreArr[i] > max){
                max = scoreArr[i];
            }
        }
        return max;
    }
    //评委打分最小值
    public static int getMin(int[] scoreArr){
        int min = scoreArr[0];
        for(int i=0; i<scoreArr.length; i++){
            if(scoreArr[i] < min){
                min = scoreArr[i];
            }
        }
        return min;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值