常见的数学方法

Math类表示数学类,其中的数学方法都被定义成为static形式,所以可以直接通过Math类的类名调用某个数学方法。语法格式:

Math.xxx(参数);

例题

输入n个整数a1,a2,a3,......an,求这n个数的最大值max,最小值min,以及|ai-aj|绝对值的最大值(i!=j)(n<=1000,ai<=1000)

实例:

输入5

1 2 3 4 5

输出1 5 4

Integer.MAX_VALUE 是 int 类型的最大值,

所以数组 f 中的第一个元素 f[0] 能够成功地将其值赋给 min。
然后,通过后续的循环逐个比较 f 数组中的其他元素,能够正确地更新 min 为更小的值。

java 复制代码
import java.util.Scanner;


public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int []f = new int[n];
/*
用 Integer.MAX_VALUE 的好处:
    在这个上下文中用作一个比数组 f 中任何可能的值都要大的"占位符",以确保 min 变量能够在后续的循环中正确地找到数组 f 的最小值
 */
        int max = 0,min = Integer.MAX_VALUE,absmax = 0;
        for (int i = 0; i < n; i++) {
            f[i] =sc.nextInt();
        }
        for (int i = 0; i < n; i++) {
            max = Math.max(f[i],max);
            min = Math.min(f[i],min);
        }
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < n; j++) {
//              避免了对同一个元素进行自己减自己的操作,因为任何数减自己都是0
                if (i == j){
                    continue;
                }
                absmax = Math.max(Math.abs(f[i]-f[j]),absmax);
            }
        }
        System.out.println(max + " " + min + " " + absmax);
    }
}
相关推荐
mit6.8241 小时前
[Lc_week] 447 | 155 | Q1 | hash | pair {}调用
算法·leetcode·哈希算法·散列表
jerry6092 小时前
优先队列、堆笔记(算法第四版)
java·笔记·算法
勤劳的牛马3 小时前
📚 小白学算法 | 每日一题 | 算法实战:加1!
算法
Epiphany.5563 小时前
基于c++的LCA倍增法实现
c++·算法·深度优先
一只码代码的章鱼3 小时前
学习笔记2(Lombok+算法)
笔记·学习·算法
jerry6093 小时前
c++流对象
开发语言·c++·算法
2301_817031655 小时前
C语言-- 深入理解指针(4)
c语言·开发语言·算法
·醉挽清风·5 小时前
学习笔记—双指针算法—移动零
c++·笔记·学习·算法
几点才到啊5 小时前
使用 malloc 函数模拟开辟一个 3x5 的整型二维数组
数据结构·算法
编程绿豆侠5 小时前
力扣HOT100之链表:23. 合并 K 个升序链表
算法·leetcode·链表