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.mzph.cn/news/682926.shtml

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

相关文章

【BIP39和BIP44】

现在的区块链地址通常是基于BIP39和BIP44提案的&#xff0c;这两个提案定义了助记词和确定性钱包的标准。 BIP39&#xff08;确定性钱包种子助记词&#xff09;: BIP39提案描述了一种生成和恢复助记词的方法&#xff0c;这些助记词可以用于生成加密货币的私钥和地址。 助记词…

K210开发环境搭建(VS Code)

一、新建一个文件夹&#xff0c;就叫K210 二、再K210文件夹里面再新建一个文件夹&#xff0c;就叫CMake 三、找到官方提供的资料包里的cmake安装包&#xff0c; 或者直接去cmake官方下载网址进行下载 CMake官方下载网址&#xff1a;https://cmake.org/download/ 四、双击安装…

12.object.assign和扩展运算法是深拷贝还是浅拷贝,两者区别

扩展运算符&#xff1a; let outObj {inObj: {a: 1, b: 2} } let newObj {...outObj} newObj.inObj.a 2 console.log(outObj) // {inObj: {a: 2, b: 2}}Object.assign(): let outObj {inObj: {a: 1, b: 2} } let newObj Object.assign({}, outObj) newObj.inObj.a 2 co…

Screw自动生成数据库文档

Screw简介 官方地址 Screw可以根据数据库中的表自动生成HTML、Word、Markdown格式的文档。 Springboot 3.1集成 生成Springboot项目 Spring Initializr Maven依赖 <dependency><groupId>cn.smallbun.screw</groupId><artifactId>screw-core</…

Nginx实战:日志按天分割

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 前言 一、方式1&#xff1a;定时任务执行分割脚本 1.分割日志脚本 2.添加定时任务 二、方式2&#xff1a;logrotate配置分割 1.logrotate简单介绍 2.新增切割ngi…

FT2232调试记录(3)

FT2232调试记录&#xff08;1&#xff09;: FT2232调试记录&#xff08;2&#xff09;: FT2232调试记录&#xff08;3&#xff09;: FT2232 SPI读写函数: 参照SPI提供的文档&#xff1a; 工程&#xff1a; SPI 写函数&#xff1a; FT_STATUS write_byte(FT_HANDLE handle…

再利用系统盘时,如何删除恢复分区(Recovery Partition)

系统盘有一个Recovery Partition&#xff0c;记录了重要的系统信息&#xff0c;不能删除。 Windows 10的 Disk Managment 不提供用户删除这个Partition的选项。 近日我插入一块原系统盘&#xff0c;Format后作为DataDisk&#xff0c;此时需要删除这块硬盘上的RecoveryPartition…

MySQL中常见的几种日志类型【重点】

在MySQL中&#xff0c;有几种不同类型的日志&#xff0c;用于记录数据库的活动和操作&#xff0c;以便于故障排查、性能调优和数据恢复等目的。以下是MySQL中常见的几种日志类型&#xff1a; 错误日志&#xff08;Error Log&#xff09;&#xff1a; 错误日志记录了MySQL服务器…

vue3 封装一个通用echarts组件

实现这个组件需要引入echarts和vue-echarts插件&#xff0c;使用vue-echarts是因为它帮我们封装了一些很常用的功能&#xff0c;比如监听页面resize后重新渲染功能&#xff0c;本次组件只使用到了autoresize配置&#xff0c;其它可以根据官方文档按需选配 https://github.com/…

11.JavaScript 中如何进行隐式类型转换?

首先要介绍ToPrimitive方法&#xff0c;这是 JavaScript 中每个值隐含的自带的方法&#xff0c;用来将值 &#xff08;无论是基本类型值还是对象&#xff09;转换为基本类型值。如果值为基本类型&#xff0c;则直接返回值本身&#xff1b;如果值为对象&#xff0c;其看起来大概…

vivado HDL编码技术

HDL编码技术 介绍 硬件描述语言&#xff08;HDL&#xff09;编码技术使您能够&#xff1a; •描述数字逻辑电路中最常见的功能。 •充分利用AMD设备的体系结构功能。 •模板可从AMD Vivado™设计套件集成设计环境中获得&#xff08;侧面&#xff09;。要访问模板&#xff…

机器学习系列——(二十一)神经网络

引言 在当今数字化时代&#xff0c;机器学习技术正日益成为各行各业的核心。而在机器学习领域中&#xff0c;神经网络是一种备受瞩目的模型&#xff0c;因其出色的性能和广泛的应用而备受关注。本文将深入介绍神经网络&#xff0c;探讨其原理、结构以及应用。 一、简介 神经网…

Python socket库 基础概念

socket库是Python中用于网络编程的标准库之一&#xff0c;它提供了创建套接字&#xff08;socket&#xff09;对象、绑定地址和端口、监听连接、接受连接、发送和接收数据等功能。 套接字是网络通信的基础&#xff0c;它允许程序之间进行数据传输和通信。 套接字类型&#xf…

【碎片知识点】安装Linux系统 VMware与kali

天命&#xff1a;VMware就是可以运行操作系统的载体&#xff0c;kali就是Linux的其中一个分支 天命&#xff1a;Linux有两个分支版本&#xff1a;centos与ubuntu&#xff0c;kali底层就是ubuntu&#xff08;所有Linux用起来都差不多&#xff0c;没啥区别&#xff09; 天命&…

CSS之选择器、优先级、继承

1.CSS选择器 常用的选择器 <body><div class"parent"><div id"one" style"background: blue" class"child">1<div class"one_one">11</div><div style"background-color: blueviole…

一个页面需要加载大量的图片,如何提升用户体验?

当网站页面需要加载大量图片时&#xff0c;优化用户体验非常关键&#xff0c;以下是一些方法来提升用户体验&#xff1a; 图片懒加载&#xff08;Lazy Loading&#xff09;&#xff1a;只加载用户可以看到的图片&#xff0c;当用户向下滚动页面时&#xff0c;再加载其他图片。这…

假期2.14

1、选择题 1.1、若有下面的变量定义&#xff0c;以下语句中合法的是&#xff08; A &#xff09;。 int i&#xff0c;a[10]&#xff0c;*p&#xff1b; A&#xff09; pa2; B&#xff09; pa[5]; C&#xff09; pa[2]2; D&#xff09; p&(i2); 1.2、…

2024LeetCode分类刷题

一、数组 88. 合并两个有序数组 public void merge(int[] nums1, int m, int[] nums2, int n) {int p1 0, p2 0;int[] sorted new int[m n];while (p1 < m || p2 < n) {int current;if (p1 m) {current nums2[p2];} else if (p2 n) {current nums1[p1];} else i…

每日一题——数字翻转

题目; 这道题看似是很简单的回文数 实则就是很简单的回文数 但是需要注意的一点是负数 可以在开头就进行判断&#xff0c;如果N<0的话就令N-N&#xff0c;将所有数都转成正数就好办了 上代码&#xff1a; #include <iostream> #include<string> #include<…

Linux 目录结构结构

Linux 目录结构结构 概念 Linux 没有 C、D、E...盘符&#xff0c;只有一个目录树。通过挂载&#xff0c;将不同的磁盘挂载到目录树下&#xff0c;通过目录访问磁盘。 ‍ 不同目录的作用 目录存放内容/作用​/​根目录&#xff0c;目录树的起点&#xff0c;存放所有文件。​…