несовместимый тип двойного массива и свойства string.split () - PullRequest
1 голос
/ 27 апреля 2011
public static void main(String[] args)
{
    String input="jack=susan,kathy,bryan;david=stephen,jack;murphy=bruce,simon,mary";
    String[][] family = new String[50][50];

    //assign family and children to data by ;
    StringTokenizer p = new StringTokenizer (input,";");
    int no_of_family = input.replaceAll("[^;]","").length();
    no_of_family++;
    System.out.println("family= "+no_of_family);
    String[] data = new String[no_of_family];
    int i=0;
    while(p.hasMoreTokens())
    {
        data[i] = p.nextToken();
        i++;
    }

    for (int j=0;j<no_of_family;j++)
    {
        family[j][0] = data[j].split("=")[0];
                    //assign child to data by commas
        StringTokenizer v = new StringTokenizer (data[j],",");
        int no_of_child = data[j].replaceAll("[^,]","").length();
        no_of_child++;

        System.out.println("data from input = "+data[j]);
        for (int k=1;k<=no_of_child;k++)
        {

            family[j][k]= data[j].split("=")[1].split(",");
            System.out.println(family[j][k]);
        }

    }

}

У меня есть список семейства во входной строке, и я делюсь на семью, и я хочу сделать это в двойном массиве [i] [j].

моя цель:

family[0][0]=1st father's name
family[0][1]=1st child name
family[0][2]=2nd child name and so on...

family[0][0]=jack
family[0][1]=susan
family[0][2]=kathy
family[0][3]=bryan
family[1][0]=david
family[1][1]=stephen
family[1][2]=jack
family[2][0]=murphy
family[2][1]=bruce
family[2][2]=simon
family[2][3]=mary

но я получил ошибку в качестве заголовка: в совместимых типах найдено: java.lang.String [] требуется: java.lang.String семейство [j] [k] = данные [j] .split ("=") [1] .split (",");

что я могу сделать? Мне нужна помощь

Кто-нибудь знает, как использовать StringTokenizer для этого ввода?

Ответы [ 3 ]

1 голос
/ 27 апреля 2011

Пытаясь понять, почему вы не можете просто использовать split для своей вложенной операции.

Например, что-то вроде этого должно работать нормально

for (int j=0;j<no_of_family;j++)
{
    String[] familySplit = data[j].split("=");

    family[j][0] = familySplit[0];

    String[] childrenSplit = familySplit[1].split(",");
    for (int k=0;k<childrenSplit.length;k++)
    {

        family[j][k+1]= childrenSplit[k];
    }

}
1 голос
/ 27 апреля 2011

Я всегда избегаю использовать массивы напрямую. Их трудно манипулировать против динамического списка. Я реализовал решение, используя карту родителя для списка детей Map<String, List<String>> (читай Map<Parent, List<Children>>).

public static void main(String[] args) {
        String input = "jack=susan,kathy,bryan;david=stephen,jack;murphy=bruce,simon,mary";

        Map<String, List<String>> parents = new Hashtable<String, List<String>>();
        for ( String family : input.split(";")) {
            final String parent = family.split("=")[0];
            final String allChildrens = family.split("=")[1];

            List<String> childrens = new Vector<String>();
            for (String children : allChildrens.split(",")) {
                childrens.add(children);
            }
            parents.put(parent, childrens);
        }

        System.out.println(parents);
    }

Вывод такой:

{jack=[susan, kathy, bryan], murphy=[bruce, simon, mary], david=[stephen, jack]}

С помощью этого метода вы можете каталогизировать доступ к родителю, используя карту:

System.out.println(parents.get("jack"));

и этот вывод:

[susan, kathy, bryan]
1 голос
/ 27 апреля 2011

Вы пытаетесь присвоить массив строк строке.Может быть, это сделает это более понятным?

String[] array = data.split("=")[1].split(",");

Теперь, если вы хотите первый элемент этого массива, вы можете сделать:

family[j][k] = array[0];
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...