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,一经查实,立即删除!

相关文章

K210开发环境搭建(VS Code)

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

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…

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

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

【碎片知识点】安装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…

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<…

4核16G服务器价格腾讯云PK阿里云

4核16G服务器租用优惠价格26元1个月&#xff0c;腾讯云轻量4核16G12M服务器32元1个月、96元3个月、156元6个月、312元一年&#xff0c;阿腾云atengyun.com分享4核16服务器租用费用价格表&#xff0c;阿里云和腾讯云详细配置报价和性能参数表&#xff1a; 腾讯云4核16G服务器价…

计算机网络概述习题拾遗

学习目标&#xff1a; 自下而上第一个提供端到端服务的层次 路由器、交换机、集线器实现的功能层 TCP/IP体系结构的网络接口层对应OSI体系结构的哪两个层次 分组数量对总时延的影响 如果这篇文章对您有帮助&#xff0c;麻烦点赞关注支持一下动力猿吧&#xff01; 学习内容…

4核16g云服务器多少钱?

4核16G服务器租用优惠价格26元1个月&#xff0c;腾讯云轻量4核16G12M服务器32元1个月、96元3个月、156元6个月、312元一年&#xff0c;阿腾云atengyun.com分享4核16服务器租用费用价格表&#xff0c;阿里云和腾讯云详细配置报价和性能参数表&#xff1a; 腾讯云4核16G服务器价…

MyBatisPlus - 润物无声、效率至上、丰富功能

目录 一、简介 1.1、为什么要使用 MybatisPlus 二、使用指南 2.1、依赖 2.2、配置 2.3、常用注解 2.4、BaseMapper 的使用 2.4.1、定义 Mapper 接口 2.4.2、基于 QueryWrapper 的查询&#xff08;不推荐&#xff09; 2.4.3、基于 UpdateWrapper 的修改&#xff08;不…

Sentinel 流控-链路模式

链路模式 A B C 三个服务 A 调用 C B 调用 C C 设置流控 ->链路模式 -> 入口资源是 A A、B 服务 package com.learning.springcloud.order.controller;import com.learning.springcloud.order.service.BaseService; import org.springframework.beans.factory.annotatio…

腾讯云4核8G服务器3年600元?

腾讯云4核8G服务器3年600元&#xff1f;目前的价格是轻量应用服务器4核8G12M带宽一年446元、646元15个月&#xff0c;云服务器CVM标准型S5实例4核8G配置价格15个月1437.3元&#xff0c;5年6490.44元&#xff0c;标准型SA2服务器1444.8元一年&#xff0c;在txy.wiki可以查询详细…

Excel一键导入导出-EasyPOI

EasyPOI是一款优秀的开源Java库&#xff0c;专为简化和优化Excel文件的导入导出操作而设计。下面&#xff0c;我会介绍EasyPOI在项目中使用EasyPOI&#xff0c;实现Excel文件的高效操作。帮助读者全面了解和掌握这一工具。 EasyPOI简介 官网&#xff1a; http://www.wupaas.co…

windows服务启动

一.NetCore 1.创建启动脚本run_instal.bat,例如程序文件为ApiDoc.exe set serviceName"Apidoc Web 01" set serviceFilePath%~dp0ApiDoc.exe set serviceDescription"ApiDoc 动态接口服务 web 01"sc create %serviceName% BinPath%serviceFilePath% sc c…

如何在Django中使用分布式定时任务并结合消息队列

如何在Django中使用分布式定时任务并结合消息队列 如何在Django中使用分布式定时任务并结合消息队列项目背景与意义实现步骤1. 安装Celery和Django-celery-beat2. 配置Celery3. 配置Django-celery-beat4. 定义定时任务5. 启动Celery worker 和 beat6. Celery 指令7. 对接消息队…

「软件设计师」操作系统基本原理

操作系统概述 操作系统与计算机体系结构之间的关系 操作系统具备的管理职能 进程管理 进程的状态前趋图pv操作死锁问题存储管理 段页式存储页面置换算法文件管理 索引文件位示图作业管理设备管理 数据传输控制方式微内核操作系统 虚设备与SPOOLING技术 进程管理 进程的状态…