C語言如何計算字符串長度
C語言計算字符串長度
思路分析
字符串的結(jié)束標志是’\0’,因此計算字符串的長度的核心思想就是通過字符指針順序檢索每一個字符,直到檢測到’\0’為止,以下是實現(xiàn)該算法的幾種方式。
代碼實現(xiàn)
1.用while循環(huán)實現(xiàn)
#define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include<windows.h> int myStrlen(char* str) { ?? ?int count = 0; ?? ?while(*str != '\0') ?? ?{ ?? ??? ?count++;//記錄字符串長度 ?? ??? ?str++; ?? ?} ?? ?return count; } int main() { ?? ?char arr[] = "bit"; ?? ?int len= myStrlen(arr); ?? ?printf("%d\n", len); ?? ?system("pause"); ?? ?return 0; }
2.用遞歸實現(xiàn)
#define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include<windows.h> int myStrlen( char *str) ? { ?? ?if ((str == NULL) || (*str == '\0'))? ?? ?{ ?? ??? ?return 0; ?? ?} ?? ?else { ?? ??? ?return myStrlen(str + 1) + 1; ?? ?} } int main() { ?? ?char arr[] = "bit"; ?? ?int len= myStrlen(arr); ?? ?printf("%d\n", len); ?? ?system("pause"); ?? ?return 0; }
3.另一種遞歸實現(xiàn)
#define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include<windows.h> #include <assert.h> int myStrlen(const char *str) ? { ?? ?assert(str != NULL); ?? ?return *str ? (myStrlen(++str) + 1) : 0; } int main() { ?? ?char arr[] = "bit"; ?? ?int len= myStrlen(arr); ?? ?printf("%d\n", len); ?? ?system("pause"); ?? ?return 0; }
計算字符串長度的函數(shù)解讀
strlen
函數(shù)求得的字符串長度是從字符串第一個元素到第一個'\0'之間元素的個數(shù)(如果字符串中間有'\0',則結(jié)果不是整個字符串的長度),同時不包括該'\0'sizeof
求得的結(jié)果是存儲該字符串的變量占用的空間大小,因而一定會包括'\0'.若'\0'后還有空余的空間,也會包含到結(jié)果里面
解釋(與2種求值方式的實現(xiàn)原理有關):
1.strlen()的一種實現(xiàn)就是遍歷字符串,遇到'\0'就終止,因而返回的結(jié)果是第一個'\0'前字符元素的個數(shù)
2.sizeof 常用來求變量占用內(nèi)存空間的大小,因而它返回的是存儲字符串的變量所占用的內(nèi)存空間大小,用來求字符串的長度,只在特定情況下可行,即字符數(shù)組剛好被一個字符串占滿。
在C語言中,與strlen函數(shù)不同的是,sizeof不是一個函數(shù),而是判斷數(shù)據(jù)類型或者表達式長度符的關鍵字,也可以說是C/C++中的一個操作符(operator),其作用就是返回一個對象或者類型所占的內(nèi)存字節(jié)數(shù)。
注意:字節(jié)數(shù)的計算在程序編譯時進行,而不是在程序執(zhí)行的過程中才計算出來!
數(shù)組的sizeof值等于數(shù)組所占用的內(nèi)存字節(jié)數(shù),如:
char a1[] = "abc"; int a2[3]; sizeof( a1 ); // 結(jié)果為4,字符末尾還存在一個NULL終止符 sizeof( a2 ); // 結(jié)果為3*4=12(依賴于int)
那么如何求數(shù)組中元素的個數(shù)呢? (以下兩種方式是等價的)
int c1= sizeof (a1)/ sizeof ( char ); //總長度/單個元素的長度 ?char型 int c2= sizeof (a2)/ sizeof (a2[0]); //總長度/第一個元素的長度 int型
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
C語言深入探究自定義類型之結(jié)構(gòu)體與枚舉及聯(lián)合
今天我們來學習一下自定義類型,自定義類型包括結(jié)構(gòu)體、枚舉、聯(lián)合體,小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考2022-05-05C++實現(xiàn)哈夫曼樹簡單創(chuàng)建與遍歷的方法
這篇文章主要介紹了C++實現(xiàn)哈夫曼樹簡單創(chuàng)建與遍歷的方法,對于C++算法的學習來說不失為一個很好的借鑒實例,需要的朋友可以參考下2014-07-07C/C++題解LeetCode1295統(tǒng)計位數(shù)為偶數(shù)的數(shù)字
這篇文章主要為大家介紹了C/C++題解LeetCode1295統(tǒng)計位數(shù)為偶數(shù)的數(shù)字示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01如何通過函數(shù)指針調(diào)用函數(shù)(實現(xiàn)代碼)
指針可以不但可以指向一個整形,浮點型,字符型,字符串型的變量,也可以指向相應的數(shù)組,而且還可以指向一個函數(shù)2013-09-09