比较数组的元素

时间:2012-08-08 11:16:53

标签: java arrays compare

请帮我解决这个问题。我想通过array2的元素扫描array1,如果在array1中找到它,则忽略array2的元素。所以只留下水果清单。但输出显示:球,铅笔。我希望它只显示水果中的元素。谢谢你的帮助

import java.util.*;
public class CountFruits
{
    public static void main(String args[])throws Exception
    {
        String array1[] = {"apple", "mango", "orange", "banana", "ball", "pencil"};
        String array2[] = {"ball", "pencil"};
        List<String> fruits = new ArrayList<String>();
        for(int x = 0; x < array1.length; x++)
        {
            for(int y = 0; y < array2.length; y++)
            {
                if(array1[x].equals(array2[y]))
                {
                    System.out.println(array1[x] + "\t" + array2[y]);
                    if(!fruits.contains(array1[x]))
                    {
                        fruits.add(array1[x]);
                    }
                }
            }//end for
        }//end for
        System.out.println("fruits: " +fruits);
    }
}

5 个答案:

答案 0 :(得分:3)

首先,我假设这是各种各样的功课,所以我不会通过修改你的代码来破坏你的练习。

这是一个想法:你需要创建一个布尔变量来指示嵌套循环是否找到了任何东西,将它设置为“未找到”进入循环,并在循环后检查它。如果循环指示已找到项目,则跳过它;否则,添加它。请记住,只有在嵌套循环完成后才能执行此操作,因此在嵌套循环内调用fruits.add为时尚早。

boolean found = false;
for(int y = 0; !found && y < array2.length; y++) {
    found |= array1[x].equals(array2[y]);
}
if (!found) ...

答案 1 :(得分:2)

如果array1[x]不在array2[x]中,您需要将if (array1[x].equals(array2[y])) { System.out.println(array1[x] + "\t" + array2[y]); } else { fruits.add(array1[x]); } 添加到列表中:

if(!fruits.contains(...))

但你会有重复的。您可以在添加之前添加条件{{1}}。

您可以使用以下算法简化代码:

  • 将array1中的所有项目添加到列表中
  • 从列表中删除array2中的项目

答案 2 :(得分:1)

if语句if(array1 [x] .equals(array2 [y]))仅适用于球和铅笔,因此水果阵列只会添加球和铅笔。 您可以将fruit数组设置为包含所有array1,然后,如果if语句为true,则从该数组中删除该元素。

或者,您可以设置一个布尔值isFruit = true(在外部for循环中)。 然后,如果if语句if(array1 [x] .equals(array2 [y]))通过,则将isFruit设置为false。 在内循环迭代之后,如果isFruit为true,则将其添加到fruit数组中。

for(int x = 0; x < array1.length; x++)
{
    boolean isFruit = true;
    for(int y = 0; y < array2.length; y++)
    {
        if(array1[x].equals(array2[y]))
        {
            System.out.println(array1[x] + "\t" + array2[y]);
            isFruit = false;
        }
        if(isFruit)
        {
            fruits.add(array1[x]);
        }
    }//end for loop
}//end for loop

答案 3 :(得分:1)

最好的方法是,如果您使用IDE,请单步执行代码,查看逻辑失败的位置。如果您没有使用调试器,那么将一些System.out.println语句放入代码中。然后,您可以确定逻辑失败的位置。 另一个解决方案是尝试我给出的第一个解决方案。也就是说,让fruit数组保存所有array1,然后删除在array2中找到的元素

答案 4 :(得分:1)

你的逻辑有两个缺陷

1)这里您添加了不应添加到水果列表中的元素。 因此,您必须检查不属于array2的元素,并且应该添加这些元素。因此,您可以在 else 部分中编写该逻辑。

2)您每次都会检查水果列表中是否已存在元素,而不是使用设置。它将禁止重复条目