簡體   English   中英

如何轉換ArrayList <String> 字符數組,然后向后打印每個單詞?

[英]How to convert ArrayList<String> to char Array and then print each word backwards?

我有一個ArrayList方法,該方法接受ArrayList並需要以相反的順序返回單詞。 我知道我需要使用toCharArray,一旦我將它們打印出來,我就需要將其添加回ArrayList中。 代碼如下。

樣品輸出應該是貓狗

應該

TAC神

public static ArrayList<String> reverseWordLetters(ArrayList<String> textArray)
{
    ArrayList<String> results = new ArrayList<String>(textArray.size());
    char [] c = new char[textArray.size()];
    for(int i = 0; i < textArray.size(); i ++)
    {
        c = textArray.get(i).toCharArray();
    }

    return results;
}
for(String s: textArray) {
    results.add(new StringBuilder(s).reverse().toString())
}
public static String reverse(String string) {

        char[] charArray = string.toCharArray();

        char tempChar;

        for (int i = 0, j = charArray.length - 1 ; i < charArray.length / 2; i++, j--) {

            tempChar = charArray[i];

            charArray[i] = charArray [j];

            charArray[j] = tempChar; 
        }

        return new String(charArray);
    }

對於簡單的反向操作(即,如果您不關心Character.MIN_SURROGATE或Character.MAX_SURROGATE之類的東西),那么以上方法就足夠了,並且在CPU和內存方面(即,如果使用音量)比使用StringBuilder效率更高。是一個問題)。

CPU:在重復執行上述反向方法和StringBuilder提供的反向方法的測試中,上述方法僅花費StringBuilder花費的55%的時間。

內存:就內存而言,上述方法在堆中少創建一個對象(未創建StringBuilder對象)

public static ArrayList<String> foo(ArrayList<String> list){
    //if the list is empty or null return
    if(list == null || list.isEmpty()){
        return list;
    }
    //go through each string item in the list
    for(int i = 0; i < list.size(); i++){
        /*
         * get the first string and convert it to char 
         * array so we can reverse the string
         */
        String s = list.remove(0);
        char c[] = s.toCharArray();

        //reverse the string
        for(int j = 0; j < c.length/2; j++){
            char tmp = c[j];
            c[j] = c[c.length-j-1];
            c[c.length-j-1] = tmp;
        }

        /*
         * add the reverse string to 
         * the end of the list
         */
        list.add(new String(c));
    }

    /*
     * return the list of strings which will
     * be in the same order but the string 
     * itself will be reversed
     */
    return list;
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM