2.15 字符串练习

1、选择题

1.1、有以下程序

int main()

{   char  a[7]="a0\0a0\0";int  i,j;

    i=sizeof(a);  j=strlen(a);   

    printf("%d  %d\n",i,j);

}   //strlen求出字符串的长度,其实是字符串中字符的个数,不包括\0

程序运行后的输出结果是    C      

A)2    2

B)7    6

C)7    2           // a 0

D)6    2

解析:sizeof求的是字符数组的内存大小,给字符数组申请多大的内存,sizeof求得的值就是多大,所以是7,strlen求出字符串的长度,是字符串中字符的个数,遇到\0就截止,所以只会计算a0\0这点的字符串的长度,为2

1.2、以下能正确定义一维数组的选项是    BC     

A)int  a[5]={0,1,2,3,4,5};

B)char  a[]={0,1,2,3,4,5};

C)char  a={'A','B','C'};

D)int  a[5]="0123";

解析:int  a[5]={0,1,2,3,4,5};初初始化一个大小为5的整数数组,但提供了6个初始值。

int  a[5]="0123"整数数组不能接受字符串作为初始值。

1.3、已有定义:char a[]="xyz",b[]={'x','y','z'};,以下叙述中正确的是   C     

A)数组a和b的长度相同

B)a数组长度小于b数组长度

C)a数组长度大于b数组长度

D)上述说法都不对

解析:字符串数组(会在末尾自动添加一个空字符'\0'作为字符串的结束标志。所以,数组的实际长度会比初始化的字符多一个。

 1.4、以下语句或语句组中,能正确进行字符串赋值的是    D    

A)char  *sp;  *sp="right!";

B)char s[10];  s="right!";

       C)char  s[10];  *s="right!";

D)char  *sp="right!";

解析:char  *sp;  *sp="right!";:sp 是一个未初始化的指针,"right!" 是一个字符串字面量,它不能被直接赋值给一个字符

char s[10];  s="right!";数组名 s 是一个指向数组首元素的常量指针,不能被赋值

char  s[10];  *s="right!";*s 表示数组 s 的第一个元素,它是一个字符。你不能将一个字符串字面量 "right!" 赋值给一个字符

1.5、有以下程序

main()

{

   char  s[]="159",*p;

   p=s;

   printf("%c",*p++);

   printf("%c",*p++);

}

程序运行后的输出结果是    A     

A)15

B)16

C)12

D)59

解析:第一次调用printf("%c",*p++);*p的值是s[0],即'1',所以打印出'1',然后p自增1,指向s[1]。第二次调用printf("%c",*p++);*p的值是s[1],即'5',所以打印出'5',然后p自增1,指向s[2]

   1.6、以下程序的输出结果是(    A    )。

main()

{  char s1[20]=“abc”,s2[20]=“123”;

  if(strcmp(s1,s2)>0)  printf(“%s\n”,s1)); //strcmp 比较字符串大小

else  printf(“%s\n”,s2);

}

(A) abc        (B) 123     (C) abc123       (D) 123abc

解析:s1 是 "abc",s2 是 "123"。,"abc" 在 "123" 之后,因此 strcmp(s1, s2) 的返回值是一个正值。因此程序会执行 printf("%s\n", s1);,输出 s1 的值,即 "abc"。

    1.7、有以下程序

#include<sthio.h>

int main()

{ char a[20],b[20],c[20]; 

scanf(“%s%s”,a,b);

gets(c); 

printf(”%s,%s,%s\n”,a,b,c);

}

程序运行时从第一行开始输入 this is a cat!<回车>,则输出结果是    D    

A)  this, is, a B) this is, a ,  cat!

C) this is  a,  cat! D)  this, is, a cat!

解析:scanf("%s %s", a, b); 会读取第一个空白字符之前的所有字符,并将它们存储在 a 中。然后它会跳过空白字符并读取下一个空白字符之前的所有字符,将它们存储在 b 中。因此,a 将包含 "this",b 将包含 "is"。gets(c); 会读取一行输入,并将其存储在 c 中。因此,c 将包含 "a cat!"。

   1.8、有以下程序

#include<stdio.h>

#include<string.h>

main()

{ char a[5][10]={"china","beijing","you","tiananmen","welcome”);

int i,j;char t[10];

for(i=0;i<4;i++) 

{

for(j=i+1;j<5;j++)

if(strcmp(a[i],a[j])>0)

{ strcpy(t,a[i]);strcpy(a[i],a[j]);strcpy(a[j],t);} 

}

puts(a[3]);

}

其输出结果是     C      

A)Beijing B)china C)welcome D)tiananmen

解析:使用了冒泡排序算法,通过比较相邻的字符串并交换它们来实现排序,排序后的数组:{"beijing","china" ,"tiananmen"  ,"welcome"  ,"you"}所以a[3]是welcome

   1.9、有以下程序

#include<stdio.h> 

int  main()

{char ch [3][5]={"AAAA","BBB","CC");

printf ("%s\n",ch[1]);

}

程序运行后的输出结果是(    D    )。

A)AAAA B)CC C)BBBCC D)BBB

解析:数组ch是一个3x5的字符数组,其中存储了三个字符串:"AAAA", "BBB", 和 "CC"。ch[1]表示数组中的第二个字符串,即"BBB"

   1.10、有以下程序(strcat 函数用以连接两个字符串)

#include <stdio.h>

#include <string.h> 

int   main()

{ char a[20]=”ABCD\0EFG\0”, b[ ]=”IJK”;

strcat(a,b); printf(“%s\n”,a);

}

程序运行后的输出结果是    B    

A)ABCDE\OFG\OIJK B)ABCDIJK

C)IJK D)EFGIJK

解析:字符串 a 中间有一个'\0',它标志着字符串的结束。字符串 a 的声明长度为 20,但实际有效的字符串内容只到第一个 \0,即 "ABCD"。字符串 b 被初始化为 "IJK",所以结果为ABCDIJK

1.11有以下程序段

char name[20];

int num;

scanf("name=%s num=%d",name,&num);

当执行上述程序段,并从键盘输入:name=Lili  num=1001<回车>后,name 的值为     A    

A)Lili B)name=Lili C)Lili num= D)name=Lili  num=1001

解析:scanf会按照格式字符串的要求解析这个输入。它会跳过"name="部分,然后读取紧随其后的字符串"Lili",并将其存储在name数组中

1.12  有以下程序

#include

#include main()

{ char str[ ][20]={“One*World”, “One*Dream!”},*p=str[1];

printf(“%d,”,strlen(p)); printf(“%s\n”,p);

}

程序运行后的输出结果是    C     

A)9,One*World B)9,One*Dream!

C)10,One*Dream! D)10,One*World

解析:str 是一个二维字符数组,包含两个字符串:"OneWorld" 和 "OneDream!"。p 是一个字符指针,指向 str 数组中的第二个字符串 "One*Dream!"。strlen(p) 会计算 p 所指向的字符串的长度,不包括末尾的空字符('\0')。第一个 printf 会输出字符串 "One*Dream!" 的长度。第二个 printf 会输出字符串 "One*Dream!" 本身。

2、填空题

    2.1、以下程序运行后的输出结果是    abcbcc    

#include "string.h"

main()

{

   char  ch[]="abc",x[3][4]; int  i;

   for(i=0;i<3;i++)   strcpy(x[i],ch);

   for(i=0;i<3;i++)   printf("%s",&x[i][i]);

   printf("\n");

}

解析:x[0] 的内容为 "abc"x[1] 的内容为 "abc"x[2] 的内容为 "abc"。接下来,printf 语句从 x[i][i] 开始打印:对于 i=0printf 从 x[0][0] 开始打印,输出 "abc"对于 i=1printf 从 x[1][1] 开始打印,输出 "bc"。对于 i=2printf 从 x[2][2] 开始打印,"c"

2.2、 以下程序的运行结果是       string s:I like it.     string t:I like it.you? How are you    

       main( )

{ char s[20]=“I like it.” , t[20]=“Are you? How are you”, c[20] ;

int i=0;

while(s[++i]!=‘\0’)

t[i]=s[i];

t[i]=0;

printf(“string s:%s\n”,s);

printf(“string t:%s\n”,t);

}

解析:字符串s初始化为"I like it."。字符串t初始化为"Are you? How are you"。字符串c虽然被声明了,但在程序中并没有使用。变量i初始化为0,用作字符串复制的索引。while循环将s字符串的内容复制到t字符串中,从s的第一个字符开始,直到遇到s的结束符\0为止。循环结束后,t字符串的当前位置(即i所指向的位置)也被设置为\0,以确保t是一个合法的C字符串。最后,程序输出两个字符串st的内容。由于st的初始值不同,并且t的前几个字符会被s的内容覆盖,因此输出结果将是:

string s:I like it. 

 string t:I like it.you? How are you

2.3、下面程序运行的结果为    30    10   30  n   Learning  

int  main()

{

 int i=10, a[]={10,20,30,15}, *p1;

 char *b=”Learning”, **p2=&b;

   p1=&i;

printf(“%4d”,*p1+20);

   for(p1=a;p1<a+4;p1+=2)

    printf(“%4d”,*p1);

  printf(“\n%c\t%s\n”,*(b+4),*p2);

}

解析:int i = 10; 定义了一个整型变量 i 并初始化为 10。char *b = "Learning"; 定义了一个字符指针 b 并指向字符串 "Learning" 的第一个字符 'L'。**p2 = &b; 定义了一个指向字符指针的指针 p2 并使其指向 bp1 = &i; 使指针 p1 指向变量 iprintf("%4d", *p1 + 20); 输出 i 的值(10)加 20,即 30,%4d 表示以至少 4 个字符的宽度输出整数,右对齐。for (p1 = a; p1 < a + 4; p1 += 2) 循环遍历数组 a,每次增加 2 个元素。在循环中:printf("%4d", *p1); 输出当前指针 p1 所指向的数组元素的值,%4d 表示以至少 4 个字符的宽度输出整数,右对齐。printf("\n%c\t%s\n", *(b + 4), *p2); 输出字符串 b 中第 5 个字符(索引从 0 开始)和 p2 所指向的字符串(即 "Learning")。\t 表示一个制表符,用于输出对齐。

第一行输出 *p1 + 20 的结果,即 30。第二行输出数组 a 中索引为偶数的元素,即 10 和 30。第三行输出字符串 b 的第 5 个字符('n')和 p2 所指向的字符串("Learning")。注意,*(b + 4) 是获取字符串 b 中第 5 个字符,而 *p2 是获取 p2 所指向的字符串,即 b 所指向的字符串。所以输出结果为:

30  
   10   30  
n   Learning
 

3、编程题

3.1、 从键盘输入两个字符串a,b ,输出其由a与b字符串中字符从小到大的顺序排列的新的字符串。试编程

#include <iostream>
#include <algorithm>
using namespace std;
int main()
{string a,b;//定义俩字符串cout << "please enter the first string : " ;cin >> a;//输入字符串acout << "please enter the second string : " ;cin >> b;//输入字符串bstring c =a+b;//将字符串a、b拼接到一起cout << "拼接后的字符串为:" << c << endl;sort(c.begin(),c.end());//排序cout << "排序后的字符串为:" << c;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/469498.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

thinkphp6入门(20)-- 如何上传图片、文件

1. 配置文件 设置上传的路径 对应文件夹 2. 前端 <div class"card-body"><h1 class"card-title">用户头像</h1><img src"../../../uploads/{$user.avatar_photo_path}" alt"avatar" height"100"/&g…

【leetcode】深搜、暴搜、回溯、剪枝(C++)2

深搜、暴搜、回溯、剪枝&#xff08;C&#xff09;2 一、括号生成1、题目描述2、代码3、解析 二、组合1、题目描述2、代码3、解析 三、目标和1、题目描述2、代码3、解析 四、组合总和1、题目描述2、代码3、解析 五、字母大小写全排列1、题目描述2、代码3、解析 六、优美的排列1…

C语言学习day13:嵌套循环+练习题(时钟+乘法表)

嵌套循环通常是外面一层for循环&#xff0c;里面n层for循环 代码&#xff1a; int main1601() {//外层执行一次&#xff0c;内层执行一周for (int i 0; i < 5; i){for (int j 0; j < 5; j){printf("i%d,j%d\n",i,j);}}system("pause");return EX…

移动机器人激光SLAM导航(五):Cartographer SLAM 篇

参考 Cartographer 官方文档Cartographer 从入门到精通 1. Cartographer 安装 1.1 前置条件 推荐在刚装好的 Ubuntu 16.04 或 Ubuntu 18.04 上进行编译ROS 安装&#xff1a;ROS学习1&#xff1a;ROS概述与环境搭建 1.2 依赖库安装 资源下载完解压并执行以下指令 https://pa…

搜索专项---最小步数模型

文章目录 魔板 一、魔板OJ链接 本题思路:最小步数模型: 将整个“图”视为一个状态也即一个节点. 状态的转移视为权值为1的边. BFS求解, 注意几点: 状态的存储: 一般用字符串存储状态, 用哈希表存储初始状态到每个状态的距离. 方案记录: 记忆数组存储. 本题中需要存储上一个状…

AI在工业物联网(IIoT)中的安全管理与应用

在开放的工业互联网环境中&#xff0c;数百万个基于物联网的终端和中间设备&#xff0c;需要全天候地持续通信并保持在线状态。不过&#xff0c;这些设备往往由于最初设计上的限制&#xff0c;在机密性、完整性、可用性、扩展性、以及互操作性上&#xff0c;存在着各种安全漏洞…

RK3568笔记十五:触摸屏测试

若该文为原创文章&#xff0c;转载请注明原文出处。 使用正点原子的ATK-RK3568板子&#xff0c;一直在测试屏幕和视频&#xff0c;突然想到触摸屏测试&#xff0c;一直没有用过&#xff0c;原子给的demo跑的是QT系统&#xff0c;触摸功能是正常的&#xff0c;测试一下&#xf…

[缓存] - 2.分布式缓存重磅中间件 Redis

1. 高性能 尽量使用短key 不要存过大的数据 避免使用keys *&#xff1a;使用SCAN,来代替 在存到Redis之前压缩数据 设置 key 有效期 选择回收策略(maxmemory-policy) 减少不必要的连接 限制redis的内存大小&#xff08;防止swap&#xff0c;OOM&#xff09; slowLog …

随机过程及应用学习笔记(三)几种重要的随机过程

介绍独立过程和独立增量过程。重点介绍两种独立增量过程-—维纳过程和泊松过程。 目录 前言 一、独立过程和独立增量过程 1、独立过程&#xff08;Independent Process&#xff09; 2、独立增量过程&#xff08;Independent Increment Process&#xff09; 二、正态过程&am…

ICLR 2023#Learning to Compose Soft Prompts for Compositional Zero-Shot Learning

组合零样本学习&#xff08;CZSL&#xff09;中Soft Prompt相关工作汇总&#xff08;一&#xff09; 文章目录 组合零样本学习&#xff08;CZSL&#xff09;中Soft Prompt相关工作汇总&#xff08;一&#xff09;ICLR 2023#Learning to Compose Soft Prompts for Compositional…

HDFS的超级用户

一. 解释原因 HDFS(Hadoop Distributed File System)和linux文件系统管理一样&#xff0c;也是存在权限控制的。 但是很不一样的是&#xff0c; 在Linux文件系统中&#xff0c;超级用户Superuser是root而在HDFS中&#xff0c;超级用户Superuser是启动了namenode的用户&#x…

解决ucore实验qemu不断重启问题

解决 ucore 实验 qemu 不断重启问题 做清华大学操作系统 ucore 实验 (x86版本)&#xff0c;实验一编译后运行 qemu 发现系统不断重启&#xff0c;无法正常运行 kernel。实验环境是 ubuntu 22.04&#xff0c;gcc 11.4.0&#xff0c;ld 2.38。最终查证是链接脚本 kernel.ld 导致…