数组与字符串C语言代码总结
《array》
arr.c
#include <stdio.h>int main(int argc, char *argv[])
{int a[2][3]; int i, j;for (i = 0; i < 2; i++) {for (j = 0; j < 3; j++) printf("%p ", &a[i][j]); //验证二维数组连续性}printf("%p %d\\n", a, sizeof(a)); //二维数组的总字节数printf("%p %d\\n", a[0], sizeof(a[0])); //单个行一维数组占用的字节数printf("%p %d\\n", a[1], sizeof(a[1]));return 0;
}
arr2.c
二维数组初始化
#include <stdio.h>int main(int argc, char *argv[])
{//int a[2][3] = {{1, 6, 9}, {2, 8, 5}}; 1.全部初始化//int a[2][3] = {{1, 6}, {2}}; 2.部分初始化//int a[][3] = {{1, 6}}; 3.行数可以省略int a[3][3] = {{1}, {2, 3}, {4}}; //int a[3][] = {{1}, {2, 3}, {4}}; 4. 声明时列数不能省略int i, j;for (i = 0; i < 3; i++) {for (j = 0; j < 3; j++)printf("%d ", a[i][j]);putchar('\\n');}return 0;
}
arr3.c
打印杨辉三角
#include <stdio.h>int main(int argc, char *argv[])
{int a[10][10] = {{0}};int i, j;for (i = 0; i < 10; i++) { //循环赋值a[i][0] = 1; //第一列都是1,比较特殊所以直接赋值for (j = 1; j <= i; j++) //j是从1开始 打印左下角是j<=i,打印右上角是j>=ia[i][j] = a[i-1][j-1] + a[i-1][j]; //元素行列的特点}for (i = 0; i < 10; i++) {for (j = 0; j <= i; j++)printf("%-8d ", a[i][j]); //循环打印 使用-8d 即左对齐8位,不足补空格,不加-号就是右对齐 putchar('\\n');}return 0;
}
demo1.c
#include <stdio.h>int main(int argc, char *argv[])
{//int i = 6, a[i];int a[6] = {1, 4, 5}, i, n; //一维数组初始化 1.数组不初始化,其元素值为随机数 2.对static数组元素不赋初值,系统会自动赋以0值 3.只给部分数组元素赋初值,其他默认为0 (图片举例) https://i.328888.xyz/2023/04/12/iBjCgV.pngint b[] = {3, 4, 7, 8, 1, 0};n = sizeof(b) / sizeof(int);for (i = 0; i < n; i++) // 数组不做越界检查,注意循环次数的限制//printf("%p %d ", &a[i], a[i]);printf("%p %d\\n", &b[i], b[i]); // 数组元素地址是连续递增的//a = a + 1; // 数组名表示内存首地址,是地址常量,不能改变printf("%p\\n", a); // 数组名表示内存首地址,可以利用sizeof计算出数组所占字节(内存空间大小)printf("%d\\n", sizeof(a));return 0;
}
细节点分析:
//数组必须先定义后使用,数组元素表示形式,数组名[下标] (其中,下标可以是常量或整型表达式)
int a[10];
printf("%d",a); //数组元素输出要使用循环,只能逐个引用数组元素,不能一次引用整个数组 (×)
for(j=0; j<10; j++)printf("%d\\t",a[j]); //正确使用循环输出一维数组
max.c
寻找数组中最大值且输出其行列
#include <stdio.h>int main(int argc, char *argv[])
{int a[2][3] = {{2, 5, 8}, {21, 56, 9}};int i, j, row, column;row = column = 0;for (i = 0; i < 2; i++) {for (j = 0; j < 3; j++) {if (a[row][column] < a[i][j]) { //用第一个数和其他所有元素比较,遇到更大的数,则将其行列赋值row = i;column = j;}}}for (i = 0; i < 2; i++) {for (j = 0; j < 3; j++)printf("%5d ", a[i][j]);putchar('\\n');}printf("max=%d %d %d\\n", a[row][column], row, column);return 0;
}
sort.c
冒泡排序(分析思路掌握)
#include <stdio.h>int main(int argc, char *argv[])
{int a[] = {3, 4, 17, 8, 31, 2, 9, 15}, n, i, j;int t;n = sizeof(a) / sizeof(int);for (i = 0; i < n-1; i++) { //比较的回数for (j = 0; j < n-1-i; j++) { //数组中元素两两比较if (a[j] > a[j+1]){t = a[j]; //从小到大排序,前一个数大于后一个数就交换a[j] = a[j+1];a[j+1] = t;}}}for (i = 0; i < n; i++) printf("%d ", a[i]); //交换完成后,输出数组排序后的值puts("");return 0;
}
编程,先搞清楚什么事,确定逻辑,然后再动手,先确定主题,再优化细节
《string》
demo1.c
#include <stdio.h>int main(int argc, char *argv[])
{char arr1[] = {'a', 'b', 'c'}; //1.初始化:逐个字符赋值char arr2[6] = {'d', 'e', 'f'}; printf("arr1:%s %p\\n", arr1, &arr1[2]); //打印出来数据不准确,当使用%s来输出一个字符数组内容的时候,前提是数组中本身应该含有'\\0',或者是一个字符串,否则两个数组之间的地址是连着的,编译器不做任何检查,会顺序打印出下一个字符数组的数据,导致程序错误(重要)printf("arr2:%s %p\\n", arr2, arr2); //C语言中无字符串变量,用字符数组处理字符串 ,结束标志是'\\0'.#if 0 // 段注释语句int i, n;n = sizeof(arr1) / sizeof(char); //2.计算数组中元素for (i = 0; i < n; i++) putchar(arr1[i]); //3.字符数组输出putchar('\\n');n = sizeof(arr2) / sizeof(char);for (i = 0; i < n; i++) putchar(arr2[i]);putchar('\\n');
#endifreturn 0;
}
demo2.c
#include <stdio.h>int main(int argc, char *argv[])
{char fruit[][20] = {"banana", "apple", "strawmerry", "watermelen"}; //字符串二维数组初始化int i, j, n, m;n = sizeof(fruit) / sizeof(fruit[0]); //计算有几个字符串m = sizeof(fruit[0]) / sizeof(char); //计算每个字符串中有几个元素for (i = 0; i < n; i++) {for (j = 0; j < m; j++)putchar(fruit[i][j]); //二维数组putchar('\\n');}return 0;
}
demo3.c
上下两个程序关联性:上面按照二维数组打印出字符数组中的值,下面用一维数组打印出字符数组中的值
#include <stdio.h>int main(int argc, char *argv[])
{char fruit[][20] = {"banana", "apple", "strawmerry", "watermelen"};int i, n;n = sizeof(fruit) / sizeof(fruit[0]);for (i = 0; i < n; i++) printf("%s\\n", fruit[i]); //一维数组return 0;
}
demo4.c
字符数组逆序输出
#include <stdio.h>int main(int argc, char *argv[])
{char arr[] = "welcome"; //字符数组以字符串形式初始化int i, n;n = sizeof(arr)/sizeof(char); for (i = n-1; i >= 0; i--) putchar(arr[i]); //直接逆序输出putchar('\\n');return 0;
}
demo5.c
#include <stdio.h>
#include <string.h> //使用字符串函数头文件#define N 20int main(int argc, char *argv[])
{//char arr[] = "welcome"; //在数组已经如上初始化了的情况下,可使用 n = sizeof(arr)/sizeof(char); 来计算字符串的长度//但如果是计算用户输入字符串的长度需要调用函数 char arr[N] = {0};int i, n;printf("Please input a string:");gets(arr); // 用户输入字符串逆序输出n = strlen(arr); //计算字符串长度 for (i = n-1; i >= 0; i--)putchar(arr[i]);putchar('\\n');return 0;
}
demo6.c
#include <stdio.h>
#include <string.h>#define N 20int main(int argc, char *argv[])
{char arr[N] = {0};int i, j, n, ch;printf("Please input a string:");gets(arr); //用gets输入数据可以带空格,而scanf是以空格作为结束符的,需要一个一个字符输入n = strlen(arr);i = 0;j = n-1;while (i < j) {ch = arr[i];arr[i] = arr[j];arr[j] = ch;i++;j--; //字符数组中内容做交换}puts(arr);return 0;
}
isalph.c
#include <stdio.h>
#include <ctype.h>int main(int argc, char *argv[])
{int ch;while ((ch = getchar()) != EOF) {if (isalpha(ch)) {if (isupper(ch))printf("Upper:%c\\n", ch);if (islower(ch))printf("Lower:%c\\n", ch);}if (isdigit(ch))printf("Digit:%d %c\\n", ch-'0', ch);putchar(ch);}return 0;
}
strcat.c
#include <stdio.h>
#include <string.h>#define N 100int main(int argc, char *argv[])
{char dest[] = "www.makeru";char src[N] = ".com.cn";strcat(dest, src);puts(src);puts(dest);return 0;
}
strcat2.c
#include <stdio.h>
#include <string.h>#define N 100int main(int argc, char *argv[])
{//char dest[] = {'a', 'b', 'c'};char dest[] = {'a', 'b', '\\0'};char src[N] = ".com.cn";strcat(dest, src);printf("dest:%p src:%p\\n", dest, src);puts(src);puts(dest);return 0;
}
strchr.c
#include <stdio.h>
#include <string.h>int main(int argc, char *argv[])
{char s1[] = "abas$f$sf";int ch;ch = '$';//printf("%p %p \\n", s1, strchr(s1, ch));//printf("%p %p \\n", s1, strrchr(s1, ch));printf("%d\\n", strchr(s1, ch)-s1);printf("%d \\n", strrchr(s1, ch)-s1);return 0;
}
strcmp.c
#include <stdio.h>
#include <string.h>int main(int argc, char *argv[])
{char s1[] = "ab";char s2[] = "abc";printf("%d\\n", strcmp(s1, s2));return 0;
}
strcpy.c
注意: 1. 字符数组1必须足够大
2. 拷贝时 ‘\\0’ 一同拷贝
#include <stdio.h>
#include <string.h>#define N 30int main(int argc, char *argv[])
{char src[] = "makeru";char dest[N];int i, n;//strcpy(dest, src);i = 0;n = strlen(src);printf("n=%d\\n", n);while ( i <= n) { //一个一个赋值 如果是 i < n ; 那就是没有拷贝 '\\0' 会出现乱码,所以一定要是 i <= n;dest[i] = src[i];i++;}puts(src);puts(dest);return 0;
}
strlen1.c
man strlen 查看函数 手册
1.主要功能 √
2.主要描述
3.需要的头文件
4.参数的意义 √
5.返回值的意义 √
特点:1.排除结束符 ‘\\0’
注意点: 1. 初始化时 ‘\\0’ 位置
#include <stdio.h>
#include <string.h>int main(int argc, char *argv[])
{//char s1[10] = {'A', '0', 'B', '\\0', 'C'}; //有一个字符串结束符,使用strlen ,只计算结束符之间的字符个数char s1[] = "makeru"; //若没有给定数组长度,则使用strlen和sizeof看具体实际元素个数printf("%d\\n", strlen(s1));printf("%d\\n", sizeof(s1)/sizeof(char)); //使用sizeof计算,则最终得到的是给定的初始化的值,而不是实际字符数组中的有效元素个数,且包含 '\\0' (重要)return 0;
}
strlen2.c
- 初始化时包含转义字符,斜杠不算在内
#include <stdio.h>
#include <string.h>int main(int argc, char *argv[])
{char s1[] = "\\tab\\nc\\vd\\\\e"; //打印 \\ 就是 \\\\char s2[]= "\\x69\\141"; // \\xhh 表示16进制 \\ddd 表示八进制printf("%d\\n", strlen(s1)); // 9 printf("%d\\n", sizeof(s1)/sizeof(char)); // 10 printf("\\n%d\\n", strlen(s2)); // 2printf("%d\\n", sizeof(s2)/sizeof(char)); // 3puts(s2);return 0;
}
strncat.c
#include <stdio.h>
#include <string.h>#define N 30int main(int argc, char *argv[])
{char src[] = "makeru";char dest[N] = ".com.cn";strncat(dest, src, 4);puts(src);puts(dest);return 0;
}
strncmp.c
#include <stdio.h>
#include <string.h>#define N 30int main(int argc, char *argv[])
{char s1[] = "QUIT";char s2[] = "quit";printf("%d\\n", strncmp(s1, s2, 4));printf("%d\\n", strcasecmp(s1, s2));return 0;
}
strncpy.c
#include <stdio.h>
#include <string.h>#define N 30int main(int argc, char *argv[])
{char src[] = "makeru";char dest[N] = ".com.cn";strncpy(dest, src, 4);puts(src);puts(dest);return 0;
}
strstr.c
#include <stdio.h>
#include <string.h>int main(int argc, char *argv[])
{char s[] = "how are you";char subs[] = "are";printf("%d\\n", strstr(s, subs)-s);return 0;
}
toupper.c
#include <stdio.h>
#include <ctype.h>int main(int argc, char *argv[])
{int ch;while ((ch = getchar()) != EOF) {if (isalpha(ch)) {if (isupper(ch)) {ch = tolower(ch);}else {ch = toupper(ch);}printf("%c\\n", ch);}}return 0;
}