版權
c語言字串操作函式有很多,這裡舉出需要用到的,其他請自行查詢。
1、len = strlen(p) ;//取字串長度
原型:size_t strlen(const char *s); 功能:統計字串string中字元的個數,字串的長度在 size_t 返回值中。
注意:strlen函式的功能是計算字串的實際長度,不包括'\0'在內。另外,strlen函式也可以直接測試字串常量的長度,如:strlen("helloworld")。
2、p1 = strchr(p, c);// 在字串中查詢指定字元
原型:char *strchr(const char *s, int c);
查詢字 串string中首次出現的位置, null結束符也包含在查詢中. 返回乙個指標, 指向字元c在字串string中首次出現的位置, 如果沒有找到, 則返回null.
p1 = strrchr(p, c);// 在字串中反向查詢
原型:char *strrchr(const char *s, int c);
查詢字元c在字串string中最後一次出現的位置, 也就是對string進行反序搜尋, 包含null結束符.
3、p2 = strstr(p, p1) ;// 查詢字串
原型:char *strstr(const char *haystack, const char *needle);
在字串haystack中查詢needle子串. 返回子串needle在haystack中首次出現位置的指標. 如果沒有找到子串needle, 則返回null. 如果子串needle為空串, 函式返回haystack.
4、strncpy(p, p1, n);// 複製指定長度字串
原型:char *strncpy(char *dest, const char *src, size_t n);
另外乙個:char *strcpy(char *dest, const char *src);
strncpy:將字串src中前n個字元拷貝到字串dest中。
strcpy:將字串src中字元拷貝到字串dest中。
那麼,在乙個母串中查詢關鍵字元(串),然後根據這個字元(串)將母串分割成若干個子字串,則**可以這樣寫:
#include #include #include int main(int agrc, const char *ar**);char *p1 = (char *)malloc(1024);while((p1 = strchr(p, ';')) != null)strncpy(tmp[i], p, strlen(p));for(j = 0; j <= i; j ) printf("tmp[%d] = %s\n", j, tmp[j]);return 0;}
在字串中刪除特定的字元(字串)。
題目 輸入兩個字串,從第一字串中刪除第二個字串中所有的字元。例如,輸入 they are students.和 aeiou 則刪除之後的第乙個字串變成 thy r stdnts.其實這類題有個特點,字串中的字元分為兩類,就可以聯想快速排序裡的將當前的陣列分為左右兩組,其中左邊的數字小於某值,右邊的數...
C 刪除字串中特定的字元
原文 處理string型別的方法del sp string str 待測試 處理c style的方法可用,可以考慮將該方法改寫為void del ch char src char ch 使其更加通用化。include include using namespace std void del sp c...
字串去除特定字元
週六,剛顧著陪女朋友玩了,九度oj想ac一道簡單的題目,結果在scanf上遇到了點問題,唉,週六大好的時間就沒有深入研究,今天趁著來公司看了一下scanf實現機制,解決了 靠,蛋疼的csdn,剛才寫了一大堆竟然沒儲存,直接上 了 題目描述 輸入字串s和字元c,要求去掉s中所有的c字元,並輸出結果。輸...