
本文将介绍如何使用 Java 编写一个函数,该函数接收一个整数数组作为输入,并返回一个新的数组,其中包含原数组中所有首尾数字相同的数字。我们将通过将数字转换为字符串,然后比较字符串的首尾字符来实现此功能。此外,为了避免结果中出现重复数字,我们将使用一个布尔数组来跟踪已添加的数字。
以下是一个 Java 方法,用于查找数组中首尾数字相同的数字:
import java.util.ArrayList;
import java.util.List;
public class FindSameFirstLastDigit {
public int[] findNumbersWithSameFirstAndLastDigits(int[] a) {
List<Integer> result = new ArrayList<>();
boolean[] numbersThatHaveBeenAdded = new boolean[a.length];
for (int i = 0; i < a.length; i++) {
for (int j = i + 1; j < a.length; j++) {
String iNumber = String.valueOf(a[i]);
String jNumber = String.valueOf(a[j]);
if (iNumber.charAt(0) == jNumber.charAt(0)
&& iNumber.charAt(iNumber.length() - 1) == jNumber.charAt(jNumber.length() - 1)) {
if (!numbersThatHaveBeenAdded[i]) {
result.add(a[i]);
numbersThatHaveBeenAdded[i] = true;
}
if (!numbersThatHaveBeenAdded[j]) {
result.add(a[j]);
numbersThatHaveBeenAdded[j] = true;
}
}
}
}
return result.stream()
.mapToInt(Integer::intValue)
.toArray();
}
public static void main(String[] args) {
FindSameFirstLastDigit finder = new FindSameFirstLastDigit();
int[] inputArray = {121, 232, 13, 4554, 11, 23, 121};
int[] resultArray = finder.findNumbersWithSameFirstAndLastDigits(inputArray);
System.out.print("Result: ");
for (int num : resultArray) {
System.out.print(num + " ");
}
System.out.println();
}
}代码解释:
findNumbersWithSameFirstAndLastDigits(int[] a) 方法:
立即学习“Java免费学习笔记(深入)”;
main(String[] args) 方法 (示例):
通过将数字转换为字符串并比较字符串的首尾字符,我们可以轻松地找到数组中首尾数字相同的数字。使用布尔数组可以有效地避免结果中出现重复数字。此方法提供了一种简单而有效的方法来解决此类问题。
以上就是查找首尾数字相同的数字:Java 教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号