案例数组:
int[] arr = {1, 2, 3, 1, 2, 3, 1, 2, 3};
找出元素1 的所有下标位置
需要得到: 0, 3, 6
要求:
a. 不允许在方法内打印展示
b. 考虑多个数据情况
c. 需要在方法外获取到下标数据信息
d. 不允许使用数组作为返回值
e. 一个方法完成
目的
(1)固定格式:public static
(2)返回值类型:返回什么内容呢?
int数据类型 返回的是目标数组中有多少个找到元素
返回0,表示没有指定元素,返回值大于等于1表示找到的个数
(3)方法名:findAllIndex 找出所有下标位置
(4)形式参数列表:
①int类型数组,作为查询数据的目标数组
②int类型数据,作为需要查询的数据
③int类型数组,用于保存被查询数据的下标保存
找到下标位置如何保存,然后让方法外可以得到?
【分析】:①下标首先是int类型;②下标可能存在多个。
【结论】:这里貌似需要一个数组,int类型数组,保存下标位置,但是数组不能作为返回值
【可行性方法】这里有且只有一个途径:在参数中加入一个数组,用于保存找到目标下标位置,这里传入保存的下标数组可以在方法内使用,并且保存数据,方法外可以获取.
【已知】有前面分析可知形式参数列表可为:
(int[] arr, int[] indexes, int find)
其中,arr 是源数据数组;indexes 保存下标的数组
indexes数组初始为: {0,0,0,0,0,0,0,0,0}
【问题描述】indexes 下标为0的元素,如果保存的数据是0的情况下,不能确定0是有效数据还是无效数据
【结论】这里需要一个数据,来辅助我们确定当前indexes数组中有多少个指定元素。(后面的count变量)
public static int findAllIndex(int[] arr, int[] indexes, int find)
package com.qfedu.a.homework;
public class HomeWork1 {
public static void main(String[] args) {
int[] arr = {1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1};
int[] indexes = new int[arr.length];
// 接受方法的返回值,得到的数查询目标数据的个数
int count = findAllIndex(arr, indexes, 1);
if (count > 0) {
for (int i = 0; i < count; i++) {
System.out.println(indexes[i]);
}
} else {
System.out.println("Not Found!");
}
}
/*
* indexes数组容量 == arr.length?
* why???
* 1. 存在可能性目标数组中的所有元素都是指定需要查询的数据
* 2. 如果大于目标数组容量,浪费空间
*/
/**
* 找出指定数组arr中,指定元素find所有的下标位置,保存到indexes数组中,返回值 是找到的目标数据个数
*
* @param arr 查询数据的目标数组
* @param indexes 保存下标信息的数组
* @param find 指定的目标数据
* @return 找到指定数据个数,返回0,表示没有找到,返回值大于0,找的元素个数
*/
public static int findAllIndex(int[] arr, int[] indexes, int find) {
// 参数合法性判断
if (indexes.length < arr.length) {
// 输入参数不合法!!!
System.out.println("Input Parameter is Invalid");
// 参数不合法,方法结束,返回0,表示没有找到数据
return 0;
}
/*
* 1. 计数,当前指定数组arr中,有多少个目标元素
* 2. count同时是indexes数组中下一次存放数据的下标位置
*/
int count = 0;
// 遍历目标数组arr
for (int i = 0; i < arr.length; i++) {
// 如果发现了指定元素 find
if (find == arr[i]) {
/*
* 需要保存下标位置到indexes数组中
* 操作过程是需要讲indexes数组中存储下标位置
* 下标位置需要放入到下一个空余位置中,同时需要
* 完成计数操作
*
* count数据刚刚好就是下一次存储数据的位置下标
*/
indexes[count] = i;
count++;
}
}
return count;
}
}