为了账号安全,请及时绑定邮箱和手机立即绑定

如何将数组的索引打印到单独的 ArrayList 中

如何将数组的索引打印到单独的 ArrayList 中

忽然笑 2021-11-24 14:40:25
我为我的程序创建了一个方法,我在其中比较了两个数组 user 和 test。当它与测试数组不同时,我试图将数组用户的索引添加到 ArrayList qMissed 中。如果两个数组完全相同,那么它应该只返回 null。我收到异常错误,因为我需要完成引用类型,但我不确定该怎么做。 /** * @param user * @param test * @return */ public static ArrayList<String> questionMissed(String[] user, String[] test)  {       ArrayList<int> qMissed = new ArrayList<int>();    for (int i = 0; i <= user.length-1; i++)    {       if (user[i] != test[i])       {          qMissed = Arrays.asList(qMissed).indexOf(user);(i+1);       }       else if (user[i] == test[i])       {          return null;        }    }    return qMissed; }
查看完整描述

3 回答

?
慕村225694

TA贡献1880条经验 获得超4个赞

您的方法似乎有一些逻辑和编译问题。


看起来你需要这个方法,


public static List<Integer> questionMissed(String[] user, String[] test) {

    List<Integer> qMissed = new ArrayList<Integer>();


    for (int i = 0; i < user.length; i++) {

        if (!user[i].equals(test[i])) {

            qMissed.add(i);

        }

    }


    return qMissed.size() == 0 ? null : qMissed;

}

修复和他们的解释,


1. Your return type has to be List<Integer> instead of ArrayList<String> because you want to return an ArrayList of Integer indexes and not string.

2. Second problem you can't use primitive type in ArrayList<int> instead you need to use ArrayList<Integer>

3. You can't compare strings with == instead you need to use equals method on string.

4. You don't have to return null inside forloop else hence else block I have removed.

5. After you exit the forloop, as you want to return null if both element's arrays matched hence this code,


return qMissed.size() == 0 ? null : qMissed;

如果您在使用此方法时遇到任何问题,请告诉我。


编辑:


如果两个传递的数组具有相同的数字,如何显示“全部正确”消息。你一定是这样称呼它的,


List<Integer> list = questionMissed(user,test);

if (list == null) {

    System.out.println("All are correct");

} else {

    // your current code

}


查看完整回答
反对 回复 2021-11-24
?
牛魔王的故事

TA贡献1830条经验 获得超3个赞

您可以尝试在方法中将返回类型从 ArrayList 更改为 ArrayList:


public static ArrayList<int> questionMissed(String[] user, String[] test) {   

        ArrayList<int> qMissed = new ArrayList<int>();

        for (int i=0;i<=user.length-1;i++) {

            if (user[i] != test[i]) {

                qMissed = Arrays.asList(qMissed).indexOf(user);(i+1);

            } else {

                return null; 

            }

       }

       return qMissed;

    }

如果条件原因是多余的,您也可以删除 else。请附上您得到的例外情况。


查看完整回答
反对 回复 2021-11-24
?
慕田峪4524236

TA贡献1875条经验 获得超5个赞

我看到您的代码存在多个问题,首先,正如 Andreas 所说 ArrayList 无法承载原始类型,因此将其更改为


ArrayList<Integer> qMissed = new ArrayList<Integer>();

我看到的第二个问题是,您使用==此比较比较字符串可能是错误的,因此请equals改用


(user[i].equals(test[i]))

我看到的最后一个错误是代码无法编译,你能否在评论中给我更多信息,说明你在这部分尝试做的事情,因为它不是有效的代码


qMissed = Arrays.asList(qMissed).indexOf(user);

(i + 1);

如果你想做类似 Pushpesh Kumar Rajwanshi 回答的事情,你可以使用 java 8 流,它的作用是创建一个具有用户长度的 IntStream,然后过滤它以仅包含在相同索引处不相等的项目,然后将其添加到qMissed.


public static List<Integer> questionMissed(String[] user, String[] test) {

    List<Integer> qMissed = new ArrayList<>();

     IntStream.range(0, user.length)

            .filter(i -> !user[i].equals(test[i]))

            .forEach(qMissed::add);

    return qMissed.size() == 0 ? null : qMissed;

}


查看完整回答
反对 回复 2021-11-24
  • 3 回答
  • 0 关注
  • 179 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信