第7章 字符数组与字符串
- 格式:pptx
- 大小:427.02 KB
- 文档页数:88
第七章字符数组与字符串【题7.29】下面是对s的初始化,其中不正确的是。
A)char s[5]={“abc”};B)char s[5]={‘a’,‘b’,‘c’}; C)char s[5]=“”;D)char s[5]=“abcdef”;【题7.30】下面程序段的运行结果是。
char c[5]={‘a’,‘b’,‘\0’,‘c’,‘\0’};printf(“%s”,c);A)‘a’‘b’B)abC)ab c【题7.31】对两个数组a和b进行如下初始化char a[]=“ABCDEF”;char b[]={‘A’, ‘B’,‘C’,‘D’,‘E’,‘F’};则以下叙述正确的是。
A)a与b数组完全相同B)a与b长度相同C)a和b中都存放字符串D)a数组比b数组长度长提示:‘\0’是字符串结束的标志【题7.32】有两个字符数组a、b,则以下正确的输入格式是。
A)gets(a,b); B)scanf(“%s %s”,a,b);C)scanf(“%s %s”,&a,&b); D)gets(“a”),get(“b”);【题7.33】有字符数组a[80]和b[80],则正确的输出形式是。
A)puts(a,b); B)printf(“%s %s”,a[],b[]);C)putchar(a,b); D)puts(a),puts(b);【题7.34】下面程序段的运行结果是。
char a[7]=“abcdef”;char b[4]=“ABC”;strcpy(a,b);printf(“%c”,a[5]);A)空格B)\0 C)e D)f提示:复制后a[0]=‘A’,a[1]=‘B’,a[2]=‘C’,a[3]=‘\0’,a[4]=‘e’,a[5 ]=‘f’,a[6]=‘\0’,【题7.35】有下面的程序段char a[3],b[]=“China”;a=b;printf(“%s”,a);则。
A)运行后将输出China B)运行后将输出ChC)运行后将输出Chi D)编译出错提示:数组名是常量【题7.36】下面程序段的运行结果是。
c语言字符串数组和字符串字面量C语言字符串数组和字符串字面量在C语言中,字符串是一种常见的数据类型,用于存储和处理文本信息。
字符串数组和字符串字面量是C语言中用来表示和操作字符串的两种主要方式。
本文将详细介绍这两种方式的特点、用法以及注意事项。
1. 字符串数组字符串数组是一种由字符组成的数组,用于存储和操作字符串。
其定义方式如下:```cchar str[20] = "Hello, world!";```其中,str是一个字符数组,长度为20,可以存储19个字符和一个结尾的空字符'\0'。
由于C语言中没有提供专门的字符串类型,所以通常使用字符数组来表示字符串。
字符串数组可以进行各种操作,比如拷贝、连接、比较等。
下面是一些常见的操作示例:- 拷贝字符串:使用strcpy函数可以将一个字符串拷贝到另一个字符串数组中。
```cchar dest[20];char src[10] = "Hello";strcpy(dest, src);```- 连接字符串:使用strcat函数可以将一个字符串连接到另一个字符串数组的末尾。
```cchar str1[20] = "Hello";char str2[10] = ", world!";strcat(str1, str2);```- 比较字符串:使用strcmp函数可以比较两个字符串的大小关系。
```cchar str1[10] = "Hello";char str2[10] = "World";int result = strcmp(str1, str2);```除了以上操作外,还可以使用字符串数组进行遍历、截取等操作。
需要注意的是,对字符串数组进行操作时,需要保证目标数组有足够的空间,以免发生数组越界的错误。
2. 字符串字面量字符串字面量是一种直接在代码中写出的字符串,也称为字符串常量。
【字符串】字符数组及其定义和初始化详解字符串的存储⽅式有字符数组和字符指针。
因为字符串是由多个字符组成的序列,所以要想存储⼀个字符串,可以先把它拆成⼀个个字符,然后分别对这些字符进⾏存储,即通过字符数组存储。
字符数组是⼀个数组,且是存储字符的数组,该数组中⼀个元素存放字符串的⼀个字符。
字符数组的定义因为字符数组⾸先是⼀个数组,所以前⾯讲的数组内容通通都适⽤。
其次它是存放字符的数组,即数组的类型是char型。
⽐如:1char name[10];表⽰定义了10字节的连续内存空间。
1)如果字符串的长度⼤于10,那么就存在语法错误。
这⾥需要注意的是,这⾥指的“字符串的长度”包括最后的‘\0’。
也就是说,虽然系统会⾃动在字符串的结尾加‘\0’,但它不会⾃动为‘\0’开辟内存空间。
所以在定义数组长度的时候⼀定要考虑‘\0’。
2)如果字符串的长度⼩于数组的长度,则只将字符串中的字符赋给数组中前⾯的元素,剩下的内存空间系统会⾃动⽤‘\0’填充。
字符数组的初始化字符数组的初始化与数组的初始化⼀样,要么定义时初始化,要么定义后初始化,下⾯写⼀个程序来说明这个问题:1 #include <stdio.h>2 #include <stdlib.h>3int main(void)4 {5char a[10];6 a[0] = 'i'; a[1] = ''; a[2] = 'l'; a[3] = 'o'; a[4] = 'v';7//空格字符的单引号内⼀定要敲空格8 a[5] = 'e'; a[6] = ''; a[7] = 'y'; a[8] = 'o'; a[9] = 'u';9//空格字符的单引号内⼀定要敲空格10 a[10] = '\0';11char b[10];12 b[0] = 'i'; b[1] = ''; b[2] = 'm'; b[3] = 'i'; b[4] = 's';13//空格字符的单引号内⼀定要敲空格14 b[5] = 's'; b[6] = ''; b[7] = 'y'; b[8] = 'o'; b[9] = 'u';15//空格字符的单引号内⼀定要敲空格16char c[] = "i believe you";17char d[] = {'i', '', 'l', 'i', 'k', 'e', '', 'y', 'o', 'u','\0'};18//空格字符的单引号内⼀定要敲空格19char e[] = {'H', 'e', 'l', 'l', 'o', '', 'W', 'o', 'r', 'l', 'd'};20//空格字符的单引号内⼀定要敲空格21char f[] = "上课睡觉觉, 下课打闹闹, 考试死翘翘";22char g[10] = "";23 printf("a = %s\n", a); //输出字符串⽤%s, 输出参数必须写数组名24 printf("b = %s\n", b);25 printf("c = %s\n", c);26 printf("d = %s\n", d);27 printf("e = %s\n", e);28 printf("f = %s\n", f);29 printf("g = %s\n", g);30return0;31 }⾸先要说明的是,这个程序只有在.cpp⽂件中才能运⾏,在.c⽂件中会有很多错误。
实验9:字符数组与字符串实验名称:字符数组与字符串成绩:实验日期:年月日实验报告日期:年月日一、实验目的1、理解字符数组和字符串的概念。
2、掌握字符数组的定义、初始、数组元素引用、输入输出。
3、掌握字符数组的处理4、掌握常用字符串处理函数二、实验内容1、编制程序:对键盘输入的字符串进行逆序,逆序后的字符串仍然保留在原来字符数组中,最后输出。
(不得调用任何字符串处理函数,包括strlen)例如:输入hello world 输出dlrow olleh2、编写程序:对键盘输入的两个字符串进行连接。
(尽管我们知道strcat()可以简单完成此任务,本题仍然规定不得调用任何字符串处理函数,包括strlen)。
例如:输入hello<CR>world<CR>,输出helloworld3、编写程序:对从键盘任意输入的字符串,将其中所有的大写字母改为小写字母,而所有小写字母改为大写字母,其它字符不变。
(不调用任何字符串处理函数)例如:输入:Hello World!输出:hELLO wORLD!4、编写程序:从键盘输入4个字符串(长度<20),存入二维字符数组中。
然后对它们进行排序(假设由小到大顺序),最后输出排序后的4个字符串。
(允许使用字符串函数)提示:字符串比较可以用strcmp函数实现,排序方法可以选择法或冒泡法。
三、实验要求1、绘制框图、编制源程序,测试数据。
2、1-3题不得使用任何字符串处理函数,4题允许使用字符串处理函数。
3、在Turbo C下完成程序的编辑、编译、运行。
查看、分析程序结果。
四、实验步骤、过程1、编辑、编译、运行程序题1。
使用数据:hello world做测试。
2、编辑、编译、运行程序题2。
使用数据:hello<CR>world<CR>做测试。
3、编辑、编译、运行程序题3。
使用数据:Hello World做测试。
4、编辑、编译、运行程序题4。
第七章数组数组是相同数据类型数据的集合。
通过数组名和下标可以访问数组中指定的元素。
7.1 一维数组一维数组只有一个下标,它可用于表示一个线性的数据队列。
在程序设计中要先声明数组,对它进行初始化,然后才能使用数组。
7.1.1 一维数组的声明一维数组的声明要解决三个问题。
第一、确定数组的数据类型。
第二、给数组定义一个名字,以便在程序中使用。
第三、指明数组的大小,也就是数组中元素的个数。
声明一维数组的一般形式如下:数据类型数组名[常量表达式]={初值表};7.1.2 一维数组的使用访问一维数组元素的一般形式是:数组名[下标表达式]下标表达式是一个整型表达式。
它是一个由整型常量、整型变量以及运算符组成的式子,也可以是返回值为整型值的函数调用。
C++规定,数组的下标从0开始,因此对于大小为N的一维数组,其下标的取值范围是0到N-1,其中0称为数组的下界,N-1称为数组的上界。
下标表达式的值应该在下标的取值范围之内,否则会产生不可预计的问题。
7.1.3一维数组的初始化通过在初值表中给出初值可以对数组元素进行初始化。
初值用一对花括号界定,初值之间用逗号进行分隔。
例7-4 int y[5]={1,2,3,4,5};1,2,3,4,5为初值表,该语句把y[0]、y[1]、y[2]、y[3]、y[4] 分别初始化为1、2、3、4、5。
通过初值表中初值的个数决定数组的大小,省略常量表达式。
例7-5 double d[]={1.5,2.3,5.6};该声明语句省略了常量表达式,数组的长度由初值表中初值的个数决定。
它说明了有三个元素的双精度数组d。
并且d[0]=1.5, d[1]=2.3, d[2]=5.6。
7.1.4 数组的运算以及数组作为函数参数1 数组的运算数组的运算最终都要归结到对数组元素的操作。
因此,数组的运算与其元素的数据类型以及系统或程序对该数据类型提供何种操作有关。
对于int、float、以及double类型的数组,赋值运算、各种算术运算、++、--等都是允许的,原因是C++提供的这些操作的操作语义支持这些数据类型的运算。