pragma mark 字符串的練習
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 給你一個字符串和一個key,要求從字符串中找出key,如果找到就返回1,沒有救返回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循環實現
int char_contains2 (char str[],char key)
{
// 通熟易懂1
// // 1.定義變量記錄當前的索引
// int index = 0;
// 2.遍歷數組,取出當前的字符判斷是否不等于key,并且當前出去的字符不是\0
/*
lyh cool
c
l != c != \0
y != c != \0
h != c != \0
空格 !=c != \0
c = !c 不滿足 條件與后面就不會判斷了 說明執行不執行 直接返回0
// 此時 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++;
// }
// 優化1
// 1.定義變量記錄當前的索引
int index = -1;
while (str[++index] != key && str[index] != '\0'); // 只要條件不滿足 一直循環
// 3.取出數組中的每個字符和key比較
// 不等于\0 說明沒有到結尾 但是找到了
// 通熟易懂3
// int res = str[index] !='\0' ? 1 : 0;
// return res;
// 優化2
return str[index] !='\0' ? 1 : 0;
}
#pragma mark for循環
//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;
}
最后編輯于 :
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。