欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言如何計算字符串長度

 更新時間:2023年02月06日 09:29:38   作者:慕白昂  
這篇文章主要介紹了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)合

    C語言深入探究自定義類型之結(jié)構(gòu)體與枚舉及聯(lián)合

    今天我們來學習一下自定義類型,自定義類型包括結(jié)構(gòu)體、枚舉、聯(lián)合體,小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考
    2022-05-05
  • C語言實戰(zhàn)之紙牌游戲

    C語言實戰(zhàn)之紙牌游戲

    這篇文章主要為大家介紹了通過C語言實現(xiàn)的紙牌游戲的示例代碼,文中的示例代碼講解詳細,對我們學習C語言有一定的幫助,感興趣的小伙伴可以跟隨小編學習一下
    2021-12-12
  • C++模擬實現(xiàn)vector流程詳解

    C++模擬實現(xiàn)vector流程詳解

    這篇文章主要介紹了C++容器Vector的模擬實現(xiàn),Vector是一個能夠存放任意類型的動態(tài)數(shù)組,有點類似數(shù)組,是一個連續(xù)地址空間,下文更多詳細內(nèi)容的介紹,需要的小伙伴可以參考一下
    2022-08-08
  • C++實現(xiàn)哈夫曼樹簡單創(chuàng)建與遍歷的方法

    C++實現(xiàn)哈夫曼樹簡單創(chuàng)建與遍歷的方法

    這篇文章主要介紹了C++實現(xiàn)哈夫曼樹簡單創(chuàng)建與遍歷的方法,對于C++算法的學習來說不失為一個很好的借鑒實例,需要的朋友可以參考下
    2014-07-07
  • 基于Matlab制作偽3D第一視角迷宮小游戲

    基于Matlab制作偽3D第一視角迷宮小游戲

    這篇文章主要為大家詳細介紹了如何利用Matlab語言制作偽3D第一視角迷宮小游戲,文中的示例代碼講解詳細,感興趣的小伙伴可以動手嘗試一下
    2022-07-07
  • C語言實現(xiàn)的猴子分桃問題算法解決方案

    C語言實現(xiàn)的猴子分桃問題算法解決方案

    這篇文章主要介紹了C語言實現(xiàn)的猴子分桃問題算法,較為詳細的分析了猴子分桃問題算法的原理與通過遞歸算法解決問題的相關實現(xiàn)技巧,需要的朋友可以參考下
    2016-10-10
  • C語言近萬字為你講透棧和隊列

    C語言近萬字為你講透棧和隊列

    對于線性表,我們可能要執(zhí)行下列操作:訪問表的第k個結(jié)點、在k這個結(jié)點之前或者之后插入一個新結(jié)點,抑或是刪除第k個結(jié)點等等操作,其中我們會遇到值對第一個或者最后一個結(jié)點插入、刪除、和訪問值的線性表,我們給它們以特殊的名稱:棧、隊列、雙端隊列
    2022-05-05
  • C語言二叉排序樹的創(chuàng)建,插入和刪除

    C語言二叉排序樹的創(chuàng)建,插入和刪除

    本文主要介紹了Java實現(xiàn)二叉排序樹的查找、插入、刪除、遍歷等內(nèi)容。具有很好的參考價值,下面跟著小編一起來看下吧
    2021-10-10
  • C/C++題解LeetCode1295統(tǒng)計位數(shù)為偶數(shù)的數(shù)字

    C/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ù)指針調(diào)用函數(shù)(實現(xiàn)代碼)

    指針可以不但可以指向一個整形,浮點型,字符型,字符串型的變量,也可以指向相應的數(shù)組,而且還可以指向一個函數(shù)
    2013-09-09

最新評論