C語(yǔ)言day08-07字符串的練習(xí)

pragma mark 字符串的練習(xí)

pragma mark 概念

pragma mark 代碼

#include <stdio.h>
int char_contains (char str[], int length ,char key);
int char_contains2 (char str[],char key);

int main()
{
#warning 給你一個(gè)字符串和一個(gè)key,要求從字符串中找出key,如果找到就返回1,沒(méi)有救返回0
    char str[] = "lyh cool";
    char key = 's';
    int length = sizeof(str) / sizeof(str[0]);
    
//    int res = char_contains(str,length,key);
    int res = char_contains2(str,key);

    printf("res = %i\n",res);
    return 0;
}
#pragma mark while循環(huán)實(shí)現(xiàn)
int char_contains2 (char str[],char key)
{
    // 通熟易懂1
//    // 1.定義變量記錄當(dāng)前的索引
//    int index = 0;
    // 2.遍歷數(shù)組,取出當(dāng)前的字符判斷是否不等于key,并且當(dāng)前出去的字符不是\0
    /*
     lyh cool  
     c
     l != c != \0
     y != c != \0
     h != c != \0
     空格 !=c != \0
     c = !c 不滿足 條件與后面就不會(huì)判斷了 說(shuō)明執(zhí)行不執(zhí)行 直接返回0

     // 此時(shí)    index= 4
     //         c !=\0 返回1
     int res = str[index] !='\0' ? 1 : 0;

     */
    
    // 通熟易懂2
//    while (str[index] != key && str[index] !='\0') {
//        printf("%c\n",str[index]);
//        index++;
//    }
    // 優(yōu)化1
    // 1.定義變量記錄當(dāng)前的索引
    int index = -1;
    while (str[++index] != key && str[index] != '\0');  // 只要條件不滿足 一直循環(huán)
    
    // 3.取出數(shù)組中的每個(gè)字符和key比較
    // 不等于\0 說(shuō)明沒(méi)有到結(jié)尾 但是找到了
    
    // 通熟易懂3
//    int res = str[index] !='\0' ? 1 : 0;
//    return res;
    // 優(yōu)化2
    return str[index] !='\0' ? 1 : 0;
    
}
#pragma mark for循環(huán)
//contains 包含
int char_contains (char str[], int length ,char key)
{
 
    for (int i = 0; i < length; i++) {
        if (str[i] == key) {
            return 1;
        }
    }
    return 0;
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容