【C 语言】字符串模型 ( 两头堵模型 )
生活随笔
收集整理的這篇文章主要介紹了
【C 语言】字符串模型 ( 两头堵模型 )
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
文章目錄
- 一、兩頭堵模型
- 二、完整代碼示例
一、兩頭堵模型
兩頭堵模型 是 有 222 個指針 , 一個指向字符串頭部 , 一個指向字符串尾部 ;
- 頭部指針 從左向右 開始遍歷 ;
- 尾部指針 從右向左 開始遍歷 ’ ’
業務邏輯 : 從 " sdfsdfsdabc4548411abc " 字符串中 , 找出 前后不為空 的 子串長度 ;
聲明兩個指針 , 分別指向開始 和 結尾處 ;
// 存在如下字符串, 求 前后不為空 的 子串長度char *str = " sdfsdfsdabc4548411abc ";// 兩個字符串索引 , i 是指向頭部 , j 指向尾部int i = 0, j = strlen(str) - 1;左側的指針從左向右遍歷 :
// 循環條件是 i 指針指向的 位置 為空 則繼續循環// 遇到第一個不為空的字符 , 便停止循環// 停止循環時的 i 指向從左側開始第一個不為空的字符while(isspace(str[i]) && str[i] != '\0'){i++;}右側的指針從右向左遍歷 :
// 循環條件是 j 指針指向的 位置 為空 則繼續循環// 遇到第一個不為空的字符 , 便停止循環// 停止循環時的 j 指向從右側開始第一個不為空的字符while(isspace(str[j]) && str[j] != '\0'){j--;}二、完整代碼示例
代碼示例 :
#include <stdio.h> #include <stdlib.h> #include <string.h>int main() {// 存在如下字符串, 求非空格子串的長度char *str = " sdfsdfsdabc4548411abc ";// 兩個字符串索引 , i 是指向頭部 , j 指向尾部int i = 0, j = strlen(str) - 1;// 保存非空字符串長度int count = 0;// 循環條件是 i 指針指向的 位置 為空 則繼續循環// 遇到第一個不為空的字符 , 便停止循環// 停止循環時的 i 指向從左側開始第一個不為空的字符while(isspace(str[i]) && str[i] != '\0'){i++;}// 循環條件是 j 指針指向的 位置 為空 則繼續循環// 遇到第一個不為空的字符 , 便停止循環// 停止循環時的 j 指向從右側開始第一個不為空的字符while(isspace(str[j]) && str[j] != '\0'){j--;}// 計算結果count = j - i + 1;// 打印結果printf("count = %d\n", count);// 命令行不要退出system("pause");return 0; }執行結果 :
count = 21 請按任意鍵繼續. . .總結
以上是生活随笔為你收集整理的【C 语言】字符串模型 ( 两头堵模型 )的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【C 语言】字符串模型 ( strstr
- 下一篇: 【C 语言】字符串模型 ( 两头堵模型