CCF(Java)系列之小中大(_20190301)

难度不难,重点是游几个坑点,一开始理所当然以为中位数是平均值,然后理所当然错误了;
然后发现若是使用除法,默认只保留整数所以小数都是0,无法作为判断,所以必须使除数声明为double;
最后,得到的时间800ms,看起来很危险将近1s,要是数值再大一点的话要使用BufferedReader;

package com.example.administrator.test.ccf;
import java.util.Scanner;
/**
 * @author kyp
 * @time 2019/7/23
 * @description 小中大  中位数,最大,最小,然后有序,可能升序或者降序
 */
public class _20190301 {
    public static void main(String[] arsg) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        int[] a = new int[n];
        for (int i = 0; i < n; i++) {
            a[i] = scanner.nextInt();
        }
        int max, min;
        double middle = 0.0;//小数点保留一位数
        if (a[n - 1] > a[0]) {
            max = a[n - 1];
            min = a[0];
        } else {
            max = a[0];
            min = a[n - 1];
        }
        if (n % 2 != 0) {
            middle = a[(n - 1) / 2];
            System.out.print(max + " " + (int) middle + " " + min);
        } else {
            double sum =0.0;
            sum= a[n / 2] + a[n / 2 - 1];
            middle = sum / 2;
            if( (middle-(int)middle) ==0){//重点是得到的值是整数还是小数
                System.out.print(max + " " + (int) middle + " " + min);
            }else {
                System.out.print(max + " " + middle + " " + min);
            }

        }

    }
}

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值