c语言基础(五)---数组

article/2025/4/20 23:52:21

c语言基础(五)—数组

文章目录

      • c语言基础(五)---数组
        • 一.一维数组
        • 二.二维数组
        • 三.数组查询
        • 四.字符数组和字符串
        • 五.字符串的输入和输出
        • 六.字符串处理函数

一.一维数组

数组的概念和定义

我们知道,要想把数据放入内存,必须先要分配内存空间。放入4个整数,就得分配4个int类型的内存空间:

int a[4];

这样,就在内存中分配了4个int类型的内存空间,共 4×4=16 个字节,并为它们起了一个名字,叫a

我们把这样的一组数据的集合称为数组(Array),它所包含的每一个数据叫做数组元素(Element),所包含的数据的个数称为数组长度(Length),例如int a[4];就定义了一个长度为4的整型数组,名字是a

数组中的每个元素都有一个序号,这个序号从0开始,而不是从我们熟悉的1开始,称为下标(Index)。使用数组元素时,指明下标即可,形式为:

arrayName[index]

arrayName 为数组名称,index 为下标。例如,a[0] 表示第0个元素,a[3] 表示第3个元素。

接下来我们就把第一行的4个整数放入数组:

a[0]=20;
a[1]=345;
a[2]=700;
a[3]=22;

这里的0、1、2、3就是数组下标,a[0]、a[1]、a[2]、a[3] 就是数组元素。

在学习过程中,我们经常会使用循环结构将数据放入数组中(也就是为数组元素逐个赋值),然后再使用循环结构输出(也就是依次读取数组元素的值),下面我们就来演示一下如何将 1~10 这十个数字放入数组中:

#include <stdio.h>
int main(){int nums[10];int i;//将1~10放入数组中for(i=0; i<10; i++){nums[i] = (i+1);}//依次输出数组元素for(i=0; i<10; i++){printf("%d ", nums[i]);}return 0;
}
-------------------------------------------------------------------------
运行结果:
1 2 3 4 5 6 7 8 9 10 

更改上面的代码,让用户输入 10 个数字并放入数组中:

#include <stdio.h>
int main(){int nums[10];int i;//从控制台读取用户输入for(i=0; i<10; i++){scanf("%d", &nums[i]);  //注意取地址符 &,不要遗忘哦}//依次输出数组元素for(i=0; i<10; i++){printf("%d ", nums[i]);}return 0;
}
------------------------------------------------------------------------------
运行结果:
22 18 928 5 4 82 30 10 666 88822 18 928 5 4 82 30 10 666 888 

最后我们来总结一下数组的定义方式:

dataType  arrayName[length];

dataType 为数据类型,arrayName 为数组名称,length 为数组长度。例如:

float m[12];  //定义一个长度为 12 的浮点型数组
char ch[9];  //定义一个长度为 9 的字符型数组

需要注意的是:

  1. 数组中每个元素的数据类型必须相同,对于int a[4];,每个元素都必须为 int。

  2. 数组长度 length 最好是整数或者常量表达式,例如 10、204 等,这样在所有编译器下都能运行通过;如果 length 中包含了变量,例如 n、4m 等,在某些编译器下就会报错,

  3. 访问数组元素时,下标的取值范围为 0 ≤ index < length,过大或过小都会越界,导致数组溢出,发生不可预测的情况,

数组内存是连续的

数组是一个整体,它的内存是连续的;也就是说,数组元素之间是相互挨着的,彼此之间没有一点点缝隙。下图演示了int a[4];在内存中的存储情形:

img

数组内存是连续的」这一点很重要,所以我使用了一个大标题来强调。连续的内存为指针操作(通过指针来访问数组元素)和内存处理(整块内存的复制、写入等)提供了便利,这使得数组可以作为缓存(临时存储数据的一块内存)使用。

数组的初始化

上面的代码是先定义数组再给数组赋值,我们也可以在定义数组的同时赋值,例如:

int a[4] = {20, 345, 700, 22};

数组元素的值由{ }包围,各个值之间以,分隔。

对于数组的初始化需要注意以下几点:

1) 可以只给部分元素赋值。当{ }中值的个数少于元素个数时,只给前面部分元素赋值。例如:
int a[10]={12, 19, 22 , 993, 344};
表示只给 a[0]~a[4] 5个元素赋值,而后面 5 个元素自动初始化为 0。
当赋值的元素少于数组总体元素的时候,剩余的元素自动初始化为 0:
对于shortintlong,就是整数 0;
对于char,就是字符 '\0';
对于floatdouble,就是小数 0.0。我们可以通过下面的形式将数组的所有元素初始化为 0int nums[10] = {0};
char str[10] = {0};
float scores[10] = {0.0};
由于剩余的元素会自动初始化为 0,所以只需要给第 0 个元素赋值为 0 即可。------------------------------------------------------------------------------------
2) 只能给元素逐个赋值,不能给数组整体赋值。例如给 10 个元素全部赋值为 1,只能写作:
int a[10] = {1, 1, 1, 1, 1, 1, 1, 1, 1, 1};
而不能写作:
int a[10] = 1;------------------------------------------------------------------------------------
3) 如给全部元素赋值,那么在定义数组时可以不给出数组长度。例如:
int a[] = {1, 2, 3, 4, 5};
等价于
int a[5] = {1, 2, 3, 4, 5};

程序实例:

#include <stdio.h>
int main()
{int a[4] = {20, 345, 700, 22};int b[4] = {56720, 9999, 20098, 2};int c[4] = {233, 205, 1, 6666};int d[4] = {34, 0, 23, 23006783};printf("%-9d %-9d %-9d %-9d\n", a[0], a[1], a[2], a[3]);printf("%-9d %-9d %-9d %-9d\n", b[0], b[1], b[2], b[3]);printf("%-9d %-9d %-9d %-9d\n", c[0], c[1], c[2], c[3]);printf("%-9d %-9d %-9d %-9d\n", d[0], d[1], d[2], d[3]);return 0;
}

二.二维数组

二维数组定义的一般形式是:

dataType arrayName[length1][length2];

其中,dataType 为数据类型,arrayName 为数组名,length1 为第一维下标的长度,length2 为第二维下标的长度。

我们可以将二维数组看做一个 Excel 表格,有行有列,length1 表示行数,length2 表示列数,要在二维数组中定位某个元素,必须同时指明行和列。例如:

int a[3][4];定义了一个 34 列的二维数组,共有 3×4=12 个元素,数组名为 a,即:
a[0][0], a[0][1], a[0][2], a[0][3]
a[1][0], a[1][1], a[1][2], a[1][3]
a[2][0], a[2][1], a[2][2], a[2][3]

如果想表示第 2 行第 1 列的元素,应该写作 a[2][1]

也可以将二维数组看成一个坐标系,有 x 轴和 y 轴,要想在一个平面中确定一个点,必须同时知道 x 轴和 y 轴。

二维数组在概念上是二维的,但在内存中是连续存放的;换句话说,二维数组的各个元素是相互挨着的,彼此之间没有缝隙。那么,如何在线性内存中存放二维数组呢?有两种方式:

  • 一种是按行排列, 即放完一行之后再放入第二行;
  • 另一种是按列排列, 即放完一列之后再放入第二列

在C语言中,二维数组是按行排列的。也就是先存放 a[0] 行,再存放 a[1] 行,最后存放 a[2] 行;每行中的 4 个元素也是依次存放。数组 a 为 int 类型,每个元素占用 4 个字节,整个数组共占用 4×(3×4)=48 个字节。

你可以这样认为,二维数组是由多个长度相同的一维数组构成的。

【实例1】一个学习小组有 5 个人,每个人有 3 门课程的考试成绩,求该小组各科的平均分和总平均分。

MathCEnglish
张涛807592
王正华616571
李丽丽596370
赵圈圈858790
周梦真767785

对于该题目,可以定义一个二维数组 a[5][3] 存放 5 个人 3 门课的成绩,定义一个一维数组 v[3] 存放各科平均分,再定义一个变量 average 存放总平均分。最终编程如下:

#include <stdio.h>
int main(){int i, j;  //二维数组下标int sum = 0;  //当前科目的总成绩int average;  //总平均分int v[3];  //各科平均分int a[5][3];  //用来保存每个同学各科成绩的二维数组printf("Input score:\n");for(i=0; i<3; i++){for(j=0; j<5; j++){scanf("%d", &a[j][i]);  //输入每个同学的各科成绩sum += a[j][i];  //计算当前科目的总成绩}v[i]=sum/5;  // 当前科目的平均分sum=0;}average = (v[0] + v[1] + v[2]) / 3;printf("Math: %d\nC Languag: %d\nEnglish: %d\n", v[0], v[1], v[2]);printf("Total: %d\n", average);return 0;
}
--------------------------------------------------------------------------
运行结果:
Input score:
80 61 59 85 76 75 65 63 87 77 92 71 70 90 85↙
Math: 72
C Languag: 73
English: 81
Total: 75

程序使用了一个嵌套循环来读取所有学生所有科目的成绩。在内层循环中依次读入某一门课程的各个学生的成绩,并把这些成绩累加起来,退出内层循环(进入外层循环)后再把该累加成绩除以 5 送入 v[i] 中,这就是该门课程的平均分。外层循环共循环三次,分别求出三门课各自的平均成绩并存放在数组 v 中。所有循环结束后,把 v[0]、v[1]、v[2] 相加除以 3 就可以得到总平均分。

二维数组的初始化(赋值)

二维数组的初始化可以按行分段赋值,也可按行连续赋值。

例如,对于数组 a5,按行分段赋值应该写作:
int a[5][3]={ {80,75,92}, {61,65,71}, {59,63,70}, {85,87,90}, {76,77,85} };按行连续赋值应该写作:
int a[5][3]={80, 75, 92, 61, 65, 71, 59, 63, 70, 85, 87, 90, 76, 77, 85};

这两种赋初值的结果是完全相同的。

【实例2】和“实例1”类似,依然求各科的平均分和总平均分,不过本例要求在初始化数组的时候直接给出成绩。

#include <stdio.h>
int main(){int i, j;  //二维数组下标int sum = 0;  //当前科目的总成绩int average;  //总平均分int v[3];  //各科平均分int a[5][3] = {{80,75,92}, {61,65,71}, {59,63,70}, {85,87,90}, {76,77,85}};for(i=0; i<3; i++){for(j=0; j<5; j++){sum += a[j][i];  //计算当前科目的总成绩}v[i] = sum / 5;  // 当前科目的平均分sum = 0;}average = (v[0] + v[1] + v[2]) / 3;printf("Math: %d\nC Languag: %d\nEnglish: %d\n", v[0], v[1], v[2]);printf("Total: %d\n", average);return 0;
}
--------------------------------------------------------------------------
运行结果:
Math: 72
C Languag: 73
English: 81
Total: 75

对于二维数组的初始化还要注意以下几点:

1) 可以只对部分元素赋值,未赋值的元素自动取“零”值。例如:
int a[3][3] = {{1}, {2}, {3}};
是对每一行的第一列元素赋值,未赋值的元素的值为 0。赋值后各元素的值为:
1  0  0
2  0  0
3  0  0再如:
int a[3][3] = {{0,1}, {0,0,2}, {3}};
赋值后各元素的值为:
0  1  0
0  0  2
3  0  0------------------------------------------------------------------------------------
2) 如果对全部元素赋值,那么第一维的长度可以不给出。例如:
int a[3][3] = {1, 2, 3, 4, 5, 6, 7, 8, 9};
可以写为:
int a[][3] = {1, 2, 3, 4, 5, 6, 7, 8, 9};-----------------------------------------------------------------------------------
3) 二维数组可以看作是由一维数组嵌套而成的;如果一个数组的每个元素又是一个数组,那么它就是二维数组。当然,前提是各个元素的类型必须相同。根据这样的分析,一个二维数组也可以分解为多个一维数组,C语言允许这种分解。例如,二维数组a[3][4]可分解为三个一维数组,它们的数组名分别为 a[0]、a[1]、a[2]。这三个一维数组可以直接拿来使用。这三个一维数组都有 4 个元素,比如,一维数组 a[0] 的元素为 a[0][0]、a[0][1]、a[0][2]、a[0][3]

三.数组查询

在实际开发中,经常需要查询数组中的元素。例如,学校为每位同学分配了一个唯一的编号,现在有一个数组,保存了实验班所有同学的编号信息,如果有家长想知道他的孩子是否进入了实验班,只要提供孩子的编号就可以,如果编号和数组中的某个元素相等,就进入了实验班,否则就没进入。

不幸的是,C语言标准库没有提供与数组查询相关的函数,所以我们只能自己编写代码。

对无序数组的查询
所谓无序数组,就是数组元素的排列没有规律。无序数组元素查询的思路也很简单,就是用循环遍历数组中的每个元素,把要查询的值挨个比较一遍。请看下面的代码:

#include <stdio.h>
int main(){int nums[10] = {1, 10, 6, 296, 177, 23, 0, 100, 34, 999};int i, num, thisindex = -1;printf("Input an integer: ");scanf("%d", &num);for(i=0; i<10; i++){if(nums[i] == num){thisindex = i;break;}}if(thisindex < 0){printf("%d isn't  in the array.\n", num);}else{printf("%d is  in the array, it's index is %d.\n", num, thisindex);}return 0;
}
----------------------------------------------------------------------
运行结果:
Input an integer: 100100 is  in the array, it's index is 7.
或者
Input an integer: 2828 isn't  in the array.

这段代码的作用是让用户输入一个数字,判断该数字是否在数组中,如果在,就打印出下标。

第10~15行代码是关键,它会遍历数组中的每个元素,和用户输入的数字进行比较,如果相等就获取它的下标并跳出循环。

注意:数组下标的取值范围是非负数,当 thisindex >= 0 时,该数字在数组中,当 thisindex < 0 时,该数字不在数组中,所以在定义 thisindex 变量时,必须将其初始化为一个负数。

对有序数组的查询

查询无序数组需要遍历数组中的所有元素,而查询有序数组只需要遍历其中一部分元素。例如有一个长度为 10 的整型数组,它所包含的元素按照从小到大的顺序(升序)排列,假设比较到第 4 个元素时发现它的值大于输入的数字,那么剩下的 5 个元素就没必要再比较了,肯定也大于输入的数字,这样就减少了循环的次数,提高了执行效率。

#include <stdio.h>
int main(){int nums[10] = {0, 1, 6, 10, 23, 34, 100, 177, 296, 999};int i, num, thisindex = -1;printf("Input an integer: ");scanf("%d", &num);for(i=0; i<10; i++){if(nums[i] == num){thisindex = i;break;}else if(nums[i] > num){break;}}if(thisindex < 0){printf("%d isn't  in the array.\n", num);}else{printf("%d is  in the array, it's index is %d.\n", num, thisindex);}return 0;
}

与前面的代码相比,这段代码的改动很小,只增加了一个判断语句,也就是 12~14 行。因为数组元素是升序排列的,所以当 nums[i] > num 时,i 后边的元素也都大于 num 了,num 肯定不在数组中了,就没有必要再继续比较了,终止循环即可。

四.字符数组和字符串

用来存放字符的数组称为字符数组,例如:

char a[10];  //一维字符数组
char b[5][10];  //二维字符数组
char c[20]={'c', '  ', 'p', 'r', 'o', 'g', 'r', 'a','m'};  // 给部分数组元素赋值
char d[]={'c', ' ', 'p', 'r', 'o', 'g', 'r', 'a', 'm' };  //对全体元素赋值时可以省去长度

字符数组实际上是一系列字符的集合,也就是字符串(String)。在C语言中,没有专门的字符串变量,没有string类型,通常就用一个字符数组来存放一个字符串。

C语言规定,可以将字符串直接赋值给字符数组,例如:

char str[30] = {"c.biancheng.net"};
char str[30] = "c.biancheng.net";  //这种形式更加简洁,实际开发中常用数组第 0 个元素为'c',第 1 个元素为'.',第 2 个元素为'b',后面的元素以此类推。为了方便,你也可以不指定数组长度,从而写作:
char str[] = {"c.biancheng.net"};
char str[] = "c.biancheng.net";  //这种形式更加简洁,实际开发中常用

给字符数组赋值时,我们通常使用这种写法,将字符串一次性地赋值(可以指明数组长度,也可以不指明),而不是一个字符一个字符地赋值,那样做太麻烦了。

这里需要留意一个坑,字符数组只有在定义时才能将整个字符串一次性地赋值给它,一旦定义完了,就只能一个字符一个字符地赋值了。请看下面的例子:

char str[7];
str = "abc123";  //错误
//正确
str[0] = 'a'; str[1] = 'b'; str[2] = 'c';
str[3] = '1'; str[4] = '2'; str[5] = '3';c

字符串结束标志(划重点)

字符串是一系列连续的字符的组合,要想在内存中定位一个字符串,除了要知道它的开头,还要知道它的结尾。找到字符串的开头很容易,知道它的名字(字符数组名或者字符串名)就可以;然而,如何找到字符串的结尾呢?C语言的解决方案有点奇妙,或者说有点奇葩。

在C语言中,字符串总是以'\0'作为结尾,所以'\0'也被称为字符串结束标志,或者字符串结束符。

'\0'是 ASCII 码表中的第 0 个字符,英文称为 NUL,中文称为“空字符”。该字符既不能显示,也没有控制功能,输出该字符不会有任何效果,它在C语言中唯一的作用就是作为字符串结束标志。

C语言在处理字符串时,会从前往后逐个扫描字符,一旦遇到'\0'就认为到达了字符串的末尾,就结束处理。'\0'至关重要,没有'\0'就意味着永远也到达不了字符串的结尾。

" "包围的字符串会自动在末尾添加'\0'。例如,"abc123"从表面看起来只包含了 6 个字符,其实不然,C语言会在最后隐式地添加一个'\0',这个过程是在后台默默地进行的,所以我们感受不到。

下图演示了"C program"在内存中的存储情形:

img

需要注意的是,逐个字符地给数组赋值并不会自动添加'\0',例如:
char str[] = {'a', 'b', 'c'};
数组 str 的长度为 3,而不是 4,因为最后没有'\0'。当用字符数组存储字符串时,要特别注意'\0',要为'\0'留个位置;这意味着,字符数组的长度至少要比字符串的长度大 1。请看下面的例子:
char str[7] = "abc123";
"abc123"看起来只包含了 6 个字符,我们却将 str 的长度定义为 7,就是为了能够容纳最后的'\0'。如果将 str 的长度定义为 6,它就无法容纳'\0'了。

有些时候,程序的逻辑要求我们必须逐个字符地为数组赋值,这个时候就很容易遗忘字符串结束标志'\0'在函数内部定义的变量、数组、结构体、共用体等都称为局部数据。在很多编译器下,局部数据的初始值都是随机的、无意义的,而不是我们通常认为的“零”值。这一点非常重要,大家一定要谨记,否则后面会遇到很多奇葩的错误。

#include <stdio.h>
int main(){char str[30] = {0};  //将所有元素都初始化为 0,或者说 '\0'char c;int i;for(c=65,i=0; c<=90; c++,i++){str[i] = c;}printf("%s\n", str);return 0;
}

字符串长度

所谓字符串长度,就是字符串包含了多少个字符(不包括最后的结束符'\0')。例如"abc"的长度是 3,而不是 4。

在C语言中,我们使用string.h头文件中的 strlen() 函数来求字符串的长度,它的用法为:

length strlen(strname);

strname 是字符串的名字,或者字符数组的名字;length 是使用 strlen() 后得到的字符串长度,是一个整数。

#include <stdio.h>
#include <string.h>  //记得引入该头文件
int main(){char str[] = "http://c.biancheng.net/c/";long len = strlen(str);printf("The lenth of the string is %ld.\n", len);return 0;
}
--------------------------------------------------------------------------------
运行结果:
The lenth of the string is 25.

五.字符串的输入和输出

字符串的输出

在C语言中,有两个函数可以在控制台(显示器)上输出字符串,它们分别是:

  • puts():输出字符串并自动换行,该函数只能输出字符串。
  • printf():通过格式控制符%s输出字符串,不能自动换行。除了字符串,printf() 还能输出其他类型的数据。
#include <stdio.h>
int main(){char str[] = "http://c.biancheng.net";printf("%s\n", str);  //通过字符串名字输出printf("%s\n", "http://c.biancheng.net");  //直接输出puts(str);  //通过字符串名字输出puts("http://c.biancheng.net");  //直接输出return 0;
}
------------------------------------------------------------------------------------
运行结果:
http://c.biancheng.net
http://c.biancheng.net
http://c.biancheng.net
http://c.biancheng.net

注意,输出字符串时只需要给出名字,不能带后边的[ ],例如,下面的两种写法都是错误的:

printf("%s\n", str[]);
puts(str[10]);

字符串的输入

在C语言中,有两个函数可以让用户从键盘上输入字符串,它们分别是:

  • scanf():通过格式控制符%s输入字符串。除了字符串,scanf() 还能输入其他类型的数据。
  • gets():直接输入字符串,并且只能输入字符串。

但是,scanf() 和 gets() 是有区别的:

  • scanf() 读取字符串时以空格为分隔,遇到空格就认为当前字符串结束了,所以无法读取含有空格的字符串。
  • gets() 认为空格也是字符串的一部分,只有遇到回车键时才认为字符串输入结束,所以,不管输入了多少个空格,只要不按下回车键,对 gets() 来说就是一个完整的字符串。换句话说,gets() 用来读取一整行字符串。
#include <stdio.h>
int main(){char str1[30] = {0};char str2[30] = {0};char str3[30] = {0};//gets() 用法printf("Input a string: ");gets(str1);//scanf() 用法printf("Input a string: ");scanf("%s", str2);scanf("%s", str3);printf("\nstr1: %s\n", str1);printf("str2: %s\n", str2);printf("str3: %s\n", str3);return 0;
}
---------------------------------------------------------------------------------
运行结果:
Input a string: C C++ Java Python↙
Input a string: PHP JavaScript↙str1: C C++ Java Python
str2: PHP
str3: JavaScript

第一次输入的字符串被 gets() 全部读取,并存入 str1 中。第二次输入的字符串,前半部分被第一个 scanf() 读取并存入 str2 中,后半部分被第二个 scanf() 读取并存入 str3 中。

注意,scanf() 在读取数据时需要的是数据的地址,这一点是恒定不变的,所以对于 int、char、float 等类型的变量都要在前边添加&以获取它们的地址。但是在本段代码中,我们只给出了字符串的名字,却没有在前边添加&,这是为什么呢?因为字符串名字或者数组名字在使用的过程中一般都会转换为地址,所以再添加&就是多此一举,甚至会导致错误了。

就目前学到的知识而言,int、char、float 等类型的变量用于 scanf() 时都要在前面添加&,而数组或者字符串用于 scanf() 时不用添加&,它们本身就会转换为地址。读者一定要谨记这一点。

其实 scanf() 也可以读取带空格的字符串

以上是 scanf() 和 gets() 的一般用法,很多教材也是这样讲解的,所以大部分初学者都认为 scanf() 不能读取包含空格的字符串,不能替代 gets()。其实不然,scanf() 的用法还可以更加复杂和灵活,它不但可以完全替代 gets() 读取一整行字符串,而且比 gets() 的功能更加强大。比如,以下功能都是 gets() 不具备的:

  • scanf() 可以控制读取字符的数目;
  • scanf() 可以只读取指定的字符;
  • scanf() 可以不读取某些字符;
  • scanf() 可以把读取到的字符丢弃。

六.字符串处理函数

字符串连接函数 strcat()

strcat 是 string catenate 的缩写,意思是把两个字符串拼接在一起,语法格式为:

strcat(arrayName1, arrayName2);
arrayName1、arrayName2 为需要拼接的字符串。

strcat() 将把 arrayName2 连接到 arrayName1 后面,并删除原来 arrayName1 最后的结束标志'\0'。这意味着,arrayName1 必须足够长,要能够同时容纳 arrayName1 和 arrayName2,否则会越界(超出范围)。

strcat() 的返回值为 arrayName1 的地址。

#include <stdio.h>
#include <string.h>
int main(){char str1[100]="The URL is ";char str2[60];printf("Input a URL: ");gets(str2);strcat(str1, str2);puts(str1);return 0;
}
----------------------------------------------------------------------------
运行结果:
Input a URL: http://c.biancheng.net/cpp/u/jiaocheng/↙
The URL is http://c.biancheng.net/cpp/u/jiaocheng/

字符串复制函数 strcpy()

strcpy 是 string copy 的缩写,意思是字符串复制,也即将字符串从一个地方复制到另外一个地方,语法格式为:

strcpy(arrayName1, arrayName2);
strcpy() 会把 arrayName2 中的字符串拷贝到 arrayName1 中,字符串结束标志'\0'也一同拷贝。请看下面的例子:
#include <stdio.h>
#include <string.h>
int main(){char str1[50] = "《C语言变怪兽》";char str2[50] = "http://c.biancheng.net/cpp/u/jiaocheng/";strcpy(str1, str2);printf("str1: %s\n", str1);return 0;
}
----------------------------------------------------------------------------------
运行结果:
str1: http://c.biancheng.net/cpp/u/jiaocheng/

你看,将 str2 复制到 str1 后,str1 中原来的内容就被覆盖了。

另外,strcpy() 要求 arrayName1 要有足够的长度,否则不能全部装入所拷贝的字符串。

字符串比较函数 strcmp()

strcmp 是 string compare 的缩写,意思是字符串比较,语法格式为:

strcmp(arrayName1, arrayName2);
arrayName1 和 arrayName2 是需要比较的两个字符串。

字符本身没有大小之分,strcmp() 以各个字符对应的 ASCII 码值进行比较。strcmp() 从两个字符串的第 0 个字符开始比较,如果它们相等,就继续比较下一个字符,直到遇见不同的字符,或者到字符串的末尾。

返回值:若 arrayName1 和 arrayName2 相同,则返回0;若 arrayName1 大于 arrayName2,则返回大于 0 的值;若 arrayName1 小于 arrayName2,则返回小于0 的值。

对4组字符串进行比较:

#include <stdio.h>
#include <string.h>
int main(){char a[] = "aBcDeF";char b[] = "AbCdEf";char c[] = "aacdef";char d[] = "aBcDeF";printf("a VS b: %d\n", strcmp(a, b));printf("a VS c: %d\n", strcmp(a, c));printf("a VS d: %d\n", strcmp(a, d));return 0;
}
---------------------------------------------------------------------
运行结果:
a VS b: 32
a VS c: -31
a VS d: 0

比较的两个字符串。
字符本身没有大小之分,strcmp() 以各个字符对应的 ASCII 码值进行比较。strcmp() 从两个字符串的第 0 个字符开始比较,如果它们相等,就继续比较下一个字符,直到遇见不同的字符,或者到字符串的末尾。
返回值:若 arrayName1 和 arrayName2 相同,则返回0;若 arrayName1 大于 arrayName2,则返回大于 0 的值;若 arrayName1 小于 arrayName2,则返回小于0 的值。

对4组字符串进行比较:

#include <stdio.h>
#include <string.h>
int main(){char a[] = "aBcDeF";char b[] = "AbCdEf";char c[] = "aacdef";char d[] = "aBcDeF";printf("a VS b: %d\n", strcmp(a, b));printf("a VS c: %d\n", strcmp(a, c));printf("a VS d: %d\n", strcmp(a, d));return 0;
}
---------------------------------------------------------------------
运行结果:
a VS b: 32
a VS c: -31
a VS d: 0

http://chatgpt.dhexx.cn/article/75GVWPlg.shtml

相关文章

JavaScript权威指南 第15章 网络编程 第三部分

JavaScript权威指南 第15章 网络编程 第三部分 可伸缩矢量图形15.7.1 在HTML中使用SVG15.7.2 编程操作SVG15.7.3 通过JavaScript创建SVG图片 15.8 < canvas>图形15.8.1 路径与多边形15.8.2 画布大小与坐标15.8.3 图形属性线条样式颜色、模式与渐变文本样式阴影半透明与合…

python对比c语言_通过实例浅析Python对比C语言的编程思想差异

我一直使用 Python&#xff0c;用它处理各种数据科学项目。 Python 以易用闻名。有编码经验者学习数天就能上手&#xff08;或有效使用它&#xff09;。 听起来很不错&#xff0c;不过&#xff0c;如果你既用 Python&#xff0c;同时也是用其他语言&#xff0c;比如说 C 的话&…

中科数创 php,PHP生成验证码 - 低调是最牛逼的炫耀 - OSCHINA - 中文开源技术交流社区...

PHP提供了一系列函数来实现在网站编程中对图像进行编辑。PHP的图像处理函数都封装在一个函数库中&#xff0c;这就是GD库。GD库用于处理图像&#xff0c;它是一个开放源码的动态创建图像的函数库&#xff0c;可以创建和操作多种不同格式的图像文件&#xff0c;并可以直接以图像…

1+X Web前端等级考证 | PHP 技术与应用(中级重点)

文章目录 动态网站动态网站开发所需构件PHP技术基础php 的诞生php 的优点php 的缺点 开发环境php 语言基础文件命名语言标记注释符与结束符常用命令和系统函数变量与常量常量变量变量与常量的差异 数据类型数据类型转换字符串数组数组转JSON 运算符流程控制流程分支 循环结构wh…

在直播卖货系统中,分销和代销是什么意思?

就在前几天&#xff0c;艾瑞咨询发布了《2020年中国直播电商生态研究报告》&#xff0c;报告中指出&#xff0c;19年至今&#xff0c;直播电商整体成交额达4512.9亿元&#xff0c;同比增长200.4%&#xff0c;占网购整体规模的4.5%&#xff0c;成长空间较大&#xff0c;预计未来…

社交零售多商户分销商城APP小程序系统

多种业务场景模式 自由灵活切换 新零售时代主流多用户商城&#xff0c;满足多种用户形态多样业务场景&#xff0c;解决线上的引流&#xff0c;推广难题&#xff01; 自营模式 1.平台建立自营线上商城&#xff0c;整合自身多渠道业务&#xff0c;通过会员、商品、订单、财务等…

微信小程序、APP分销商城开发:分销功能模块设计

前面我们讲了微信小程序商城基础营销功能&#xff1a;微信小程序商城、APP商城开发营销活动功能策划&#xff08;拼团、砍价、秒杀、直播、优惠券等&#xff09; 今天讲的分销系统更是强大的营销功能&#xff0c;它应该如何设计呢&#xff1f;我们的系统经过一点一点更改更新&…

人人商城源码怎么安装MySQL_人人商城12个常见错误解决方案

人人商城12个常见错误解决方案 微信小程序报错request:fail url not in domain list 有两个原因第一个是报错提示说请求的url不在域名列表里&#xff0c;应该是还没有配置服务器域名&#xff0c;可点击开发者工具右上角 详情-域名信息&#xff0c;看看是否配置了域名&#xff1…

三级分销商城  避坑避雷指南

三级分销自出现以来就引发社会各界的关注&#xff0c;这种病毒式的传播方式产生的盈利效果&#xff0c;让许多商家都蠢蠢欲动&#xff0c;相比于这种模式的风险性&#xff0c;如何去赚钱才是商家最关心的事情&#xff0c;基于三级分销模式研发的三级分销商城也成为企业发展线上…

小程序分销平台商城开发系统

小程序分销平台商城开发系统找何经理。小程序分销商城、小程序分销系统平台等。从更广阔的视角来说,目前移动互联正在给我们的世界带来新的沟通、学习、工作、生活方式,并将引领未来的潮流。不再是单纯的电子渠道建设、业务线上迁移与技术改造升级,而是一场使企业产品创新、…

三级分销系统哪家好

众所周知&#xff0c;如今许多年轻人都纷纷挤进创业这个行列&#xff0c;使得各行各业的商业市场竞争日趋激烈。在这个问题面前&#xff0c;企业如何最大程度的做好营销推广&#xff0c;使销售业绩达到最高值呢&#xff1f;当然&#xff0c;我们不得不承认互联网是最有效果的渠…

PHP商城源码分销奖励/绑定关系设计

来客推PHP分销商城源码是通过互联网将供应商与经销商有机地联系在一起&#xff0c;打造多层级的分销成交平台。 通过分享、邀请等方式绑定上下级关系&#xff0c;把会员和消费者变成分销商&#xff0c;让分销商宣传售卖商品。 分销商获得佣金和奖励&#xff0c;而供货商得到低成…

CRMEB v3.1分销设计思路

1、CRMEB分销模式有几种&#xff0c;有什么区别&#xff1f; 两种分销模式&#xff0c;指定分销和人人分销&#xff1b;指定分销&#xff1a;用户默认无分销权限&#xff0c;需要后台开通分销权限后&#xff0c;才可以推广下级获得返佣&#xff1b;人人分销&#xff1a;用户默…

人人商城小程序消息服务器配置,微擎系统人人商城小程序前端配置教程

人人商城是目前微信商城系统里面用的最多的程序&#xff0c;它功能强大&#xff0c;支持多商户入驻、分销功能、拼团活动、秒杀活动、直播购物功能等。现在更是支持了微信小程序功能&#xff0c;那么人人小程序是如何安装的呢。 首先你得准备认证服务号、服务器、备案域名。人人…

直播教育平台源码中的人人分销是什么?如何实现?

根据艾瑞咨询发布的《2020年H1中国教育行业广告主营销策略研究报告》显示&#xff0c;近段时间&#xff0c;在线教育的市场投放成本节节高升。对于刚刚崛起的在线教育来说&#xff0c;如何低成本获客就成为了一个非常重要的问题。其中&#xff0c;在直播教育平台源码中加入人人…

免费分销工具—运营指南分销系统

免费分销工具—运营指南分销系统 疫情之下,无人出门到陆续复工,餐饮、教培、旅游等实体行业行业到店消费人数并未猛然上涨,所谓的“报复性消费”仍未到来,实体行业店面收入远远低于成本,经营极度困难。 在这种困境下,如何增加订单,获取更多顾客,实现逆势增长? 01 …

公排系统php,全球公排自动滑落二二复制多级分销系统PHP二二复制多级分销源码...

菜鸟源码网分享全球公排自动滑落二二复制多级分销系统PHP二二复制多级分销源码&#xff0c;站长测试源码安装和后台登陆功能设置保存正常&#xff0c;用户端注册登录购买商品正常&#xff0c;商户端登陆添加商品等正常。PHP全球公排自动滑落 二二复制 九九复制带加权分红系统&a…

火遍全网的全民分销系统,你了解多少?

随着互联网的发展&#xff0c;用户流量也逐渐壮大&#xff0c;对于企业来说&#xff0c;平台发展需要流量&#xff0c;怎么样获取流量一个重点问题&#xff0c;随着电商的深入发展&#xff0c;人们探索出各种更深层次挖掘流量的办法&#xff0c;全民分销系统就是其中一种&#…

公排系统php,全球公排自动滑落二二复制多级分销系统 PHP源码

详细制度讲解 1、分销与公排并行1&#xff0d;9级自定义设置分销层级 2&#xff0d;9级自定义递增排位公排&#xff1a;二二复制、三三复制………九九复制 2、威 信分销的状态可以开启或关闭&#xff0c;由您说了算(关闭分销后将不再启用分销和公排) 公排的状态可以开启或关闭(…

php商城开发人人分销团队级差分红升级规则订制

注&#xff1a;所有内容可定制开发&#xff0c;可单独模块更新&#xff0c;联系QQ:1002424826&#xff0c;微信&#xff1a;php510666 使用须知 1.如果您已经在使用本系统&#xff0c;即表示您已经同意以下免责声明条款&#xff0c;否则请立即停止使用本系统。 2.使用方在使用…