Java算法之串的簡(jiǎn)單處理
題目如下:
串的處理
在實(shí)際的開發(fā)工作中,對(duì)字符串的處理是最常見的編程任務(wù)。
本題目即是要求程序?qū)τ脩糨斎氲拇M(jìn)行處理。具體規(guī)則如下:
1. 把每個(gè)單詞的首字母變?yōu)榇髮憽?/p>
2. 把數(shù)字與字母之間用下劃線字符(_)分開,使得更清晰
3. 把單詞中間有多個(gè)空格的調(diào)整為1個(gè)空格。
例如:
用戶輸入:
you and me what cpp2005program
則程序輸出:
You And Me What Cpp_2005_program
用戶輸入:
this is a 99cat
則程序輸出:
This Is A 99_cat
我們假設(shè):用戶輸入的串中只有小寫字母,空格和數(shù)字,不含其它的字母或符號(hào)。
每個(gè)單詞間由1個(gè)或多個(gè)空格分隔。
假設(shè)用戶輸入的串長(zhǎng)度不超過200個(gè)字符。
方法一:
public class 串的簡(jiǎn)單處理 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
String string = scanner.nextLine();
Vector<Character> vector = new Vector<Character>();
for (int i = 0; i < string.length(); i++) {
vector.add(string.charAt(i));
}
try {
int index = 0;
while (index < vector.size()) {
//判斷第一個(gè)是否為小寫的英文字符,是的話進(jìn)行操作
if (index == 0 && vector.elementAt(index) >= 'a'
&& vector.elementAt(index) <= 'z') {
//Replaces the element at the specified position in this Vector with the specified element
vector.set(index,(char) (vector.elementAt(index) - ('a' - 'A')));
} else if (vector.elementAt(index - 1) == ' '&& vector.elementAt(index) == ' ') {
//處理有多個(gè)空格的可能
vector.remove(index);
index--;
} else if (vector.elementAt(index - 1) == ' '
&& (vector.elementAt(index) >= 'a' && vector
.elementAt(index) <= 'z')) {
//判斷是空格后邊的字符
vector.set(index,
(char) (vector.elementAt(index) - ('a' - 'A')));
} else if ((vector.elementAt(index) >= 'a' && vector
.elementAt(index) <= 'z')
&& (vector.elementAt(index - 1) >= '0' && vector
.elementAt(index - 1) <= '9')) {
vector.add(index, '_');
index++;
} else if ((vector.elementAt(index - 1) >= 'a' && vector
.elementAt(index - 1) <= 'z')
&& (vector.elementAt(index) >= '0' && vector
.elementAt(index) <= '9')) {
//判斷的是數(shù)字
vector.add(index, '_');
index++;
}
index++;
}
for (int i = 0; i < vector.size(); i++) {
System.out.print(vector.elementAt(i));
}
System.out.println();
} catch (ArrayIndexOutOfBoundsException e) {
}
}
}

方法二:主要用到正則表達(dá)式對(duì)字符串進(jìn)行截取,然后對(duì)每一個(gè)字符數(shù)組的元素進(jìn)行正則匹配,含有數(shù)字的單獨(dú)進(jìn)行處理
public class SimpleString {
// 打印字符串的函數(shù)
public static void print(String[] s) {
for (int i = 0; i < s.length - 1; i++) {
System.out.print(s[i] + " ");
}
System.out.println(s[s.length - 1]);
}
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
String s = scan.nextLine();
String[] ss = s.split("[\\s]+"); // 根據(jù)正則表達(dá)式,刪除一個(gè)或多個(gè)空格,將字符串保存為字符數(shù)組
for (int i = 0; i < ss.length; i++) {
// 將每一個(gè)字符數(shù)組的首字母改為大寫
String up = ("" + ss[i].charAt(0)).toUpperCase(); // 大寫
StringBuffer sb = new StringBuffer(ss[i]);
ss[i] = sb.replace(0, 1, up).toString();
// 上邊已經(jīng)把字符串?dāng)?shù)組的首字母該為大寫,然后對(duì)更改后的字符數(shù)組判斷是否有數(shù)字
Matcher m = Pattern.compile("\\d+").matcher(ss[i]);// 0-9出現(xiàn)一次或多次
while (m.find()) {
// m.group():Returns the input subsequence matched by the previous match
String num = new String(m.group());
String num2 = num;
num2 = "_" + num + "_"; // 數(shù)字前后都添加"_"
ss[i] = ss[i].replace(num, num2);
if (ss[i].startsWith("_")) { // 去頭"_"
ss[i] = ss[i].substring(1);
}
if (ss[i].endsWith("_")) { // 去尾"_"
ss[i] = ss[i].substring(0, ss[i].length() - 1);
}
}
}
print(ss);
}
}

總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
- Java算法之?dāng)?shù)組冒泡排序代碼實(shí)例講解
- Java算法實(shí)現(xiàn)調(diào)整數(shù)組順序使奇數(shù)位于偶數(shù)之前的講解
- Java算法實(shí)現(xiàn)楊輝三角的講解
- Java算法之冒泡排序?qū)嵗a
- Java算法之最長(zhǎng)公共子序列問題(LCS)實(shí)例分析
- java算法實(shí)現(xiàn)紅黑樹完整代碼示例
- Java算法之堆排序代碼示例
- java算法之二分查找法的實(shí)例詳解
- java算法導(dǎo)論之FloydWarshall算法實(shí)現(xiàn)代碼
- java算法實(shí)現(xiàn)預(yù)測(cè)雙色球中獎(jiǎng)號(hào)碼
- Java算法之遞歸算法計(jì)算階乘
- JAVA算法起步之插入排序?qū)嵗?/a>
- JAVA算法起步之堆排序?qū)嵗?/a>
- JAVA算法起步之快速排序?qū)嵗?/a>
- 關(guān)于各種排列組合java算法實(shí)現(xiàn)方法
- Java算法之時(shí)間復(fù)雜度和空間復(fù)雜度的概念和計(jì)算
相關(guān)文章
Java實(shí)體類中Set按照對(duì)象的某個(gè)字段對(duì)set排序
這篇文章主要介紹了Java實(shí)體類中Set按照對(duì)象的某個(gè)字段對(duì)set排序,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-06-06
java實(shí)現(xiàn)ssh連接服務(wù)器的方法步驟
本文主要介紹了java實(shí)現(xiàn)ssh連接服務(wù)器的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-09-09
Java實(shí)現(xiàn)監(jiān)聽UDP協(xié)議的指定端口并收到數(shù)據(jù)按照十六進(jìn)制輸出方式
這篇文章主要介紹了Java實(shí)現(xiàn)監(jiān)聽UDP協(xié)議的指定端口并收到數(shù)據(jù)按照十六進(jìn)制輸出方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-04-04
詳解springboot如何更新json串里面的內(nèi)容
這篇文章主要為大家介紹了springboot 如何更新json串里面的內(nèi)容,文中有詳細(xì)的解決方案供大家參考,對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2023-10-10
Java listener簡(jiǎn)介_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了Java listener簡(jiǎn)介,可以用于統(tǒng)計(jì)用戶在線人數(shù)等,有興趣的可以了解一下2017-07-07

