本专栏开启,目的在于帮助大家更好的掌握学习Java
,特别是一些Java学习者
难以在网上找到系统地算法学习资料帮助自身入门算法,同时对于专栏内的内容有任何疑问都可在文章末尾添加我的微信给你进行一对一的讲解。
但最最主要的还是需要独立思考,对于本专栏的所有内容,能够进行完全掌握,自己完完全全将代码写过一遍,对于算法入门肯定是没有问题的。
算法的学习肯定不能缺少总结,这里我推荐大家可以到高校算法社区将学过的知识进行打卡,以此来进行巩固以及复习。
学好算法的唯一途径那一定是题海战略,大量练习的堆积才能练就一身本领。专栏的任何题目我将会从【题目描述】【解题思路】【模板代码】【代码解析】等四板块进行讲解。
从一堆数中,获得最大与最小值。这种需求的场景是非常多见的,今天我们也来仔细分析究竟有多少种操作可以完成我们的需求。
给定三个整数
a b c
,请你输出三个数中最大的数与最小的数。
难 度 评 级 难度评级 难度评级:⭐️
这种只有三个数字,需要我们找出最大值与最小值的情况,我们一般是无法去进行排序的,因为通常它们三个是不在一个数组中的。这时我们要用到Math
类中的函数max
与min
了。
import java.util.*;
public class Main{
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int a=sc.nextInt();
int b=sc.nextInt();
int c=sc.nextInt();
int max=Math.max(Math.max(a,b),c);
int min=Math.min(Math.min(a,b),c);
System.out.println(max);
System.out.println(min);
}
}
Math
的意思是数学,顾名思义,它内部自带了许许多多强大的关于数学的库函数功能。max
函数可以传入两个参数,它将返回较大值,而min
将返回最小值。两个函数暂时已知可以传入的基本类型有int
、long
、double
、float
,当然传入的两个参数类型要一致。a,b,c
只有三个数,我们只需要嵌套使用max
和min
函数即可返回答案再输出。给定一个整数 n ( 0 ≤ n ≤ 1000 ) n( 0\leq n \leq 1000) n(0≤n≤1000),接下来输出 n n n 个整数 a i ( − 1 0 4 ≤ a i ≤ 1 0 4 ) a_i(-10^4 \leq a_i \leq 10^4) ai(−104≤ai≤104),请你输出最大的整数和最小的整数是多少?
难 度 评 级 难度评级 难度评级:⭐️
由于 n n n可能非常大,直接一行使用max
或者min
函数肯定是非常不方便的,代码会非常长,此时我们考虑结合循环
来完成操作。
import java.util.*;
public class Main{
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int n=sc.nextInt();
//m1记录最大值,m2记录最小值
int m1=Integer.MIN_VALUE;
int m2=Integer.MAX_VALUE;
for (int i = 0; i < n; i++) {
int x=sc.nextInt();
m1=Math.max(m1,x);
m2=Math.min(m2,x);
}
}
}
Integer.MIN_VALUE
,表示负无穷,这样能够保证无论选中任何数都一定会比m1大,也就一定能更新答案Integer.MAX_VALUE
,这样无论选中任何数都一定比m2小,也就一定能更新答案。给定一个整数 n ( 0 ≤ n ≤ 1000 ) n( 0\leq n \leq 1000) n(0≤n≤1000),接下来输出 n n n 个整数 a i a_i ai,请你输出最大的整数和最小的整数的下标 i i i 是多少?如果有相同的最大或者最小的数,请输出最小的下标
难 度 评 级 难度评级 难度评级:⭐️⭐️
这道题在上一道题进行了变形,我们需要去记录最大值和最小值的下标。所以需要手动去判断一下是否更新了最大值和最小值,同时再用两个变量去更新下标。
import java.util.*;
public class Main{
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
int n=sc.nextInt();
//m1记录最大值,m2记录最小值
int m1=Integer.MIN_VALUE;
int m2=Integer.MAX_VALUE;
int maxIndex=-1;
int minIndex=-1;
for (int i = 0; i < n; i++) {
int x=sc.nextInt();
if (x>m1){
m1=x;
maxIndex=i;
}
if (x<m2){
m2=x;
minIndex=i;
}
}
System.out.println(maxIndex);
System.out.println(minIndex);
}
}
序号 | 题目链接 | 难度评级 |
---|---|---|
1 | 值相等的最小索引 | 1 |
2 | 找到最接近0的数字 | 1 |