#include <stdio.h>
#include <string.h>
int main(int argc, const char * argv[])
{
// 输入的字符串的长度要小于数组的长度
char str[4] = "abc"; //这么写的时候 数组长度必须是 个数 +1 , 因为需要 '\0'
char str2[4] = { 'a', 'b', 'c', '\0' };
char str3[] = "hello world"; // 为了避免错误 可以不指定 大小.
printf("%s\n", str2); //字符数组想用 %s 格式输出 必须满足 后面 \0 不然获取错误.
// 从给定的地址开始, 一直输出字符, 直到遇到\0 停止了
printf("%s\n", str3);
printf("%s\n", &str3[0]);
printf("%s\n", &str3[3]);
char ch[] = { 'a', 'b', 'c' };
char ch1[] = { 'x', 'y', 'z' };
printf("%s\n", ch1); // %s 格式输出 一直打印 直到遇到 0 , 所以 即便想打印 ch1 , 会输出xyzabc
// 因为 内存的存储方式 先写的变量 存入高地址, 所以 低xyz abc高 , 指针是从 低地址 开始读取, 往高地址走..
printf("%lu\n", sizeof(str2)); // 别跟 %s的情况 弄混了, 长度就是长度, 只要在定义的时候 {}里面的都是个数+1;
char str4[] = "abc\0";
printf("sizeof = %lu\n", sizeof(str4)); // sizeof 内存存储空间大小(0 与 0之前的元素个数, 包含0)
printf("strlen = %lu\n", strlen(str4)); // strlen 除了 \0 之外的之前的元素个数, 遇0 也会推出...
char * ss = "hello world";
char key = 'w';
int searchChar(char * str, char key);
int a = searchChar(ss, key);
printf("%d\n", a);
//************************ stone ***
char * sss = "aabbaaccaaddee";
char k = 'a';
int buf[sizeof(sss)];
int length = 0;
void searchAllCharacter(char * str, char key, int * arr, int * length);
searchAllCharacter(sss, k, buf, &length);
for (int i = 0; i < length; i++) {
printf("%d\t", buf[i]);
}
printf("\n");
return 0;
}
// 只能查找一个, 那要有多个呢?
int searchChar(char * str, char key)
{
// int i = 0;
// while (str[i] != '\0') {
// if (str[i] == key) {
// return i;
// }
// else {
// i++;
// }
// }
for (int i = 0; str[i] != '\0'; i++) {
if (str[i] == key) {
return i;
}
}
return -1;
}
void searchAllCharacter(char * str, char key, int * arr, int * length)
{
int j = 0;
for (int i = 0; str[i] != '\0'; i++) {
if (str[i] == key) {
arr[j] = i;
j++;
(*length)++;
}
}
}