字串反轉

2021-08-27 03:15:43 字數 890 閱讀 2456

把乙個句子中的單詞進行反轉,例如「how are you",進行反轉後」you are how「;

策略:1先將整個句子進行反轉

2.分別對每個單詞進行反轉

package com.luo.stringtest;

public class reversestring

public string swapwords(string s)

//1.字串轉換為字元陣列 chs:how are you

char chars = s.tochararray();

// system.out.println("字串轉換成字元陣列:");

// for (char ch:chars)

// system.out.println();

//2.對整個字串進行字串反轉操作

swap(chars,0,chars.length-1);

//3.對單個單詞進行反轉操作

int begin = 0;

for(int i=0;i}

//對最後乙個單詞進行反轉

swap(chars,begin,chars.length-1);

//利用string的建構函式將字元陣列轉換成字串

return new string(chars);

}private void swap(char chars, int front, int end)

// system.out.println("字元陣列反**");

// for (char ch:chars)

// system.out.println();

}}

字串反轉

據說一道微軟的面試題,要求考慮時間和空間的優化,下面給出幾種通常字串反轉的方法 1 直接陣列操作 char strreverse char str return str 這種做法原來的str沒有儲存,原來的str也改變了 2 指標操作 char strreverse char str return ...

字串反轉

include include include 方法一 將第乙個字元和最後乙個互換,第二個和倒數第二個互換,如此依次迴圈下去 char strrev1 const char str return tmp free tmp 方法二 不額外申請一片儲存字串的記憶體空間,通過中間變數來改變傳遞進來的字串裡...

字串反轉

解法一 第一次看到這題目,想到最簡單 最直覺的解法就是 遍歷字串,將第乙個字元和最後乙個交換,第二個和倒數第二個交換,依次迴圈,即可,於是有了第乙個解法 const char str return tmp 這裡是通過陣列的下標方式訪問字串的字元,實際上用指標直接操作即可。解法二正是基於此,實現 為 ...