Java常用字串反轉的五種方案大綱
java程式中如何一個字串進行反轉?或者在字串中指定部分進行反轉的方法有哪些?為幫助大家解決這個疑問,yjbys小編為同學們分享最新Java常用字串反轉的五種方案,快來看看吧!
Java常用字串反轉的5種方案,程式碼如下:
第一個類是執行類
package everse;
import ner;
public class Run {
public Run() {
t("請輸入一個字串:");
Scanner sc = new Scanner();
String str = ();
tln();
String reversedStrByArray = new Reverse(str)rseByArray();
tln("對應反轉字串為[Array]:"+ reversedStrByArray);
String reversedStrByStack = new Reverse(str)rseByStack();
tln("對應反轉字串為[Stack]:"+ reversedStrByStack);
String reversedStrBySort = new Reverse(str)rseBySort();
tln("對應反轉字串為[逆序遍歷]:"+ reversedStrBySort);
String reversedStrByBit = new Reverse(str)rseByBit();
tln("對應反轉字串為[位運算]:"+ reversedStrByBit);
String reversedStrByRecursive = new Reverse(str)rseByRecursive(str);
tln("對應反轉字串為[遞迴]:"+ reversedStrByRecursive); }
public static void main(String[] args) {
new Run();
}
}
第二段程式碼是實現類
package everse;
import k;
public class Reverse {
String str = new String();
public Reverse(String str) {
= str;
}
//用陣列實現
public String reverseByArray() {
if(str == null th() == 0) {
return str;
}
int len = th();
char[] chArray = arArray();
for(int i= 0; i< len/2; i++) {
char temp;
temp = chArray[i];
chArray[i] = chArray[len- 1- i];
chArray[len- 1- i] = temp;
}
return new String(chArray);
}
//用棧實現
public String reverseByStack() {
if(str == null th() == 0) {
return str;
}
Stack strStack = new Stack();
char[] chArray = arArray();
for(Character ch: chArray) {
(ch);
}
int len = th();
for(int i= 0; i< len; i++) { chArray[i] = ();
}
return new String(chArray);
}
//用逆序遍歷實現
public String reverseBySort() {
if(str == null th() == 0) {
return str;
}
StringBuilder sb = new StringBuilder();
for(int i= th()- 1; i>= 0; i--) {
nd(At(i));
}
return ring();
}
//用位運算實現
public String reverseByBit() {
if(str == null th() == 0) {
return str;
}
char[] chArray = arArray();
int len = th();
for(int i= 0; i< len/ 2; i++) {
chArray[i]^= chArray[len- 1- i];
chArray[len- 1- i]^= chArray[i];
chArray[i]^= chArray[len- 1- i];
}
return new String(chArray);
}
//用遞迴實現
public String reverseByRecursive(String str) {
if(str == null th() == 0) {
return str;
}
int len = th();
if(len == 1) {
return str;
} else {
return reverseByRecursive(tring(1))+ At(0);
}
}
}
-
Java main方法經典面試題及答案
本文是yjbys小編認為比較經典的關於Javamain方法的面試題,與其說是Java面試題,其實也是Java的一些最基礎知識問題,分享給大家,希望對大家面試有所幫助!1.不用main方法如何定義一個類?不行,沒有main方法我們不能執行Java類。在Java7之前,你可以通過使用靜態初始化執行...
-
Java開發崗位面試題「彙總」
下面是我自己收集整理的Java崗位今天面經遇到的面試題,可以用它來好好準備面試。Java基礎1.String類為什麼是final的。2.HashMap的原始碼,實現原理,底層結構。3.說說你知道的幾個Java集合類:list、set、queue、map實現類咯。4.描述一下ArrayList和LinkedList各自實現...
-
最新java面試題及答案
Java的資料型別與機器無關,Java虛擬機器(JavaVirtualMachine)是建立在硬體和作業系統之上,實現Java二進位制程式碼的解釋執行功能,提供於不同平臺的介面的。下面是小編收集的關於java面試題及答案,希望大家認真閱讀!1、面向物件的特徵有哪些方面1.抽象:抽象就是忽略一個主...
-
2016年最新JAVA程式設計題及答案
【程式1】題目:打印出所有的"水仙花數",所謂"水仙花數"是指一個三位數,其各位數字立方和等於該數本身。例如:153是一個"水仙花數",因為153=1的三次方+5的三次方+3的三次方。1.程式分析:利用for迴圈控制100-999個數,每個數分解出個位,十位,百位。【程式2】題目:古典問題:有...