1

だから私はこれらの行を含むファイルを持っています

155, 490, 297, 490,
-45, 19, 45, 19,
-24, 80,-12,-69, 80,
12,-92, 28,-40,

ファイルを読み取って、重複する要素を含むこれらの行を見つけようとしました。しかし、私のロジックの何かが間違っていて、エラーを見つけることができません。助けはありますか?

コードは次のとおりです。

public static void main(String[] args) throws IOException {
        Scanner fileInput = null;
        try {
            fileInput = new Scanner( new File("array_list.csv"));
            String line;
            while (fileInput.hasNextLine()) {
                line = fileInput.nextLine(); 
                String[] lineArr = line.split(",");
                // check for missing values
                boolean contains = true;
                for(int i=0; i<lineArr.length; i++) {
                    for(int j=0; j<lineArr.length; j++) {
                        if(lineArr[i]==lineArr[j]) {
                            contains = false;
                            break;
                        }
                    }
                    if(!contains) {
                        // print the row .....
                    }
                    else {
                        contains = true;
                        // print some thing ...
                    }
                }
            }
            } finally {
            if (null != fileInput) {
                fileInput.close();
            }
        }
    }
4

7 に答える 7

0

Stringを使用して比較する必要がありequals()ます。

ただし、コードには他の問題があります。ある時点でijは等しいため、lineArr[i]==lineArr[j]常に true になります。

重複をチェックする簡単な方法は、 a を使用してSetそのサイズをチェックすることです:

Set<String> lineSet = new HashSet<lineArr.length>;
for(String s : lineArr) {
    lineSet.add(s);
}
if(lineSet.size() < lineArr.length) {
    // there are duplicates
}
于 2013-10-22T07:24:50.050 に答える
0

重複する要素を見つけるための私のコードは次のとおりです

import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;

public class StringManipulation {
    public static void main(String[] args) {

        StringManipulation manipulation=new StringManipulation();
        manipulation.findDuplicateElementList();
        //manipulation.findDuplicateElementbyMap();

    }

    private void findDuplicateElementList() {

        String lineData = "ashish manish ashish manish sachin manish ashish neha manish";

        String[] list = lineData.split(" ");

        List<String> stringList = Arrays.asList(list);

        // containingList=stringList;
        Set<String> stringSet = new HashSet<String>();

        for (int i = 0; i < stringList.size(); i++) {
            int count = 0;
            String currVal = stringList.get(i);

            if (stringSet.contains(currVal)) {
                continue;
            } else {

                for (String string : stringList) {
                    if (currVal.equals(string)) {
                        stringSet.add(currVal);
                        count++;

                    }

                }
            }

            System.out.println("Occurances of " + currVal + " " + count);

        }
    }


}
于 2014-02-11T09:21:04.293 に答える
0

public static void main(String[] args) throws IOException{

    Scanner fileInput = null;
    try {           
        fileInput = new Scanner(new File("array_list.csv"));
        String line;
        while (fileInput.hasNextLine()) {

            line = fileInput.nextLine(); 
            String[] lineArr = line.split(",");
            // check for missing values
            boolean contains = true;
            for(int i=0; i<lineArr.length; i++) {

                for(int j=0; j<i; j++) {
                    if(lineArr[i].equals(lineArr[j])) {
                        contains = false;
                        break;
                    }
                }

            }
            if(!contains) {
                System.out.println(line);
            }
            else {
                contains = true;
            }
        }
        } finally {
        if (null != fileInput) {
            fileInput.close();
        }
    }
}
于 2013-10-22T07:37:26.670 に答える