题目描述
输入一个整数n,然后输入n个字符串,将这个n个字符串保存在数组中。寻找上述数组元素中按字典顺序比较最小的字符串(你可直接使用compareTo方法判断大小),在一个独立行中输出这个字符串在数组中的下标、字符串本身的值,中间用空格分开。如果有多个满足要求的元素,只需输出其中下标最大的那个元素的相关内容。
输入样例
5
beautiful am peace holy am
输出样例
4 am
程序代码
import java.util.Scanner;
public class Main{
public static void main(String[] args) { // 主方法
int min_index = 0; // 最小的字符串索引
Scanner n_scanner = new Scanner(System.in); // 输入 beautiful am peace holy am
int n = n_scanner.nextInt(); // 输入一个整数n
Scanner str_scanner = new Scanner(System.in);
String[] str_arr = new String[n]; // 创建字符串数组对象
for(int i = 0; i < n; i++) {
str_arr[i] = str_scanner.next(); // 对字符串数组赋值
}
for (int i = 0; i < str_arr.length - 1; i++) {
if(str_arr[0].compareTo(str_arr[i + 1]) >= 0){ // 数组元素中按字典顺序比较最小的字符串
str_arr[0] = str_arr[i + 1]; // 找到最小字符串赋值给字串数组的第一个元素
min_index = i + 1; // 找到最小字符串的下标赋值给 min_index
}
}
System.out.println(min_index + " " + str_arr[0]); // 输出下标和最大的那个元素的相关内容
}
}
注:
compareTo()
方法用于两种方式的比较:
- 字符串与对象进行比较。
- 按字典顺序比较两个字符串。
返回值是整型,它是先比较对应字符的大小(ASCII码顺序),如果第一个字符和参数的第一个字符不等,结束比较,返回他们之间的差值,如果第一个字符和参数的第一个字符相等,则以第二个字符和参数的第二个字符做比较,以此类推,直至比较的字符或被比较的字符有一方结束。
例如
String str1; String str2;
str1.compareTo(str2);
- 如果str1等于str2,则返回值 0;
- 如果str1小于str2,则返回一个小于 0 的值;
- 如果str1大于str2,则返回一个大于 0 的值。