C++實(shí)現(xiàn)字符串刪除字符后逆序輸出
本文實(shí)例為大家分享了C++實(shí)現(xiàn)字符串刪除字符后逆序輸出的具體代碼,供大家參考,具體內(nèi)容如下
輸入若干個(gè)字符串,和一個(gè)英文字符ch。 要求刪除每個(gè)字符串中的字符ch(區(qū)分大小寫(xiě)),得到新的字符串,然后將新的字符串按照字典逆序排序后輸出
(每個(gè)字符串的長(zhǎng)度不超過(guò)30個(gè)字符,字符串總數(shù)不超過(guò)30)
輸入:
3
abcddc
sxwcdez
ncvccvd
c
輸出:
sxwdez
nvvd
abdd
C++實(shí)現(xiàn):(適用于初學(xué)者)
#include <iostream> #include <cstring> using namespace std; void sort_array(char s[][30], int n); void removing(char s[][30], int n, char ch); int main() { int n, i; char s[30][30] = {0}; char ch; cout << "input the number of strings:" << endl; cin >> n; cin.get();//注意要把/n從輸入流中去除 for (i = 0; i < n; ++i) { cout << "input the NO." << i + 1 << " string:" << endl; cin.getline(s[i], 30); } cout << "input ch:" << endl; ch = cin.get(); removing(s, n, ch); sort_array(s, n); for (i = 0; i < n; ++i) { cout << s[i] << endl;//二維字符串?dāng)?shù)組可以通過(guò)這種方式直接輸出 } return 0; } void sort_array(char s[][30], int n) { int i, j, k, temp; for (j = 0; j < n - 1; ++j) { bool sort_flag = false; //相當(dāng)于一個(gè)冒泡排序,這里排序使用了strcmp for (i = 0; i < n - j - 1; ++i) { char str_temp[30] = {0}; temp = strcmp(s[i], s[i + 1]); if (temp >= 0)continue; if (temp < 0) { for (k = 0; k < 30; ++k) { str_temp[k] = s[i][k]; } for (k = 0; k < 30; ++k) { s[i][k] = s[i + 1][k]; } for (k = 0; k < 30; ++k) { s[i + 1][k] = str_temp[k]; } sort_flag = true; } } if (!sort_flag) { break; } } } void removing(char s[][30], int n, char ch) { bool flag = false; int i, j, k; for (i = 0; i < n; ++i) { for (j = 0; s[i][j] != '\0'; ++j) { if (s[i][j] == ch) { flag = true; //去除字符后把后面的往前面移動(dòng)一位 for (k = j; s[i][k] != '\0'; ++k) { s[i][k] = s[i][k + 1]; } } else { flag = false; } if (flag) { j -= 1; } } } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于C++復(fù)制構(gòu)造函數(shù)的實(shí)現(xiàn)講解
今天小編就為大家分享一篇關(guān)于關(guān)于C++復(fù)制構(gòu)造函數(shù)的實(shí)現(xiàn)講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-12-12從頭學(xué)習(xí)C語(yǔ)言之二維數(shù)組
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言之二維數(shù)組,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-01-01c/c++ 利用sscanf進(jìn)行數(shù)據(jù)拆分操作
這篇文章主要介紹了c/c++ 利用sscanf進(jìn)行數(shù)據(jù)拆分操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12C語(yǔ)言示例講解while循環(huán)語(yǔ)句的用法
在不少實(shí)際問(wèn)題中有許多具有規(guī)律性的重復(fù)操作,因此在程序中就需要重復(fù)執(zhí)行某些語(yǔ)句。一組被重復(fù)執(zhí)行的語(yǔ)句稱之為循環(huán)體,C語(yǔ)言while語(yǔ)句可以是單個(gè)語(yǔ)句,也可以是一個(gè)語(yǔ)句塊,其條件可以是任意表達(dá)式,true是任意非零值,當(dāng)條件為真時(shí),循環(huán)進(jìn)行迭代2022-06-06C語(yǔ)言入門(mén)篇--函數(shù)及數(shù)組用法
本篇文章是c語(yǔ)言基礎(chǔ)篇,主要為大家介紹了C語(yǔ)言的函數(shù)與數(shù)組,每個(gè)函數(shù)本質(zhì)上都實(shí)現(xiàn)一個(gè)最小的功能,而main函數(shù)只負(fù)責(zé)調(diào)用函數(shù),實(shí)現(xiàn)代碼的核心邏輯,提高代碼的可維護(hù)性2021-08-08C++ 中滾動(dòng)條的滾動(dòng)問(wèn)題
本文主要通過(guò)一個(gè)示例,給大家介紹了C++中滾動(dòng)條的滾動(dòng)問(wèn)題,以及相關(guān)參數(shù)的解釋,非常的詳細(xì),有需要的小伙伴可以參考下。2015-06-06

C++實(shí)現(xiàn)含附件的郵件發(fā)送功能