C及C++每日练习(1)

一.选择:

1.以下for循环的执行次数是()

 for(int x = 0, y = 0; (y = 123) && (x < 4); x++);

A.是无限循环 B.循环次数不定 C.4次 D.3次

对于for循环,其组成部分可以四个部分:
 

for(初始化;循环进行条件;调整)
{循环语句//
}

对于上面给出的for循环的循环条件,由于中间用于&&连接,因此,必须左右的条件都为真,循环才能继续进行。因此,当循环进行五次时,此时的y==4,不满足条件,退出循环,因此答案选择:C循环四次

2.以下程序的运行结果是()

 #include <stdio.h> 
int main(void) { printf("%s , %5.3s\n", "computer", "computer"); return 0; 
}

A.computer , puter

B. computer , com

C. computer , computer

D.computer , compu.ter

此题目的考点主要在于打印的格式,即题目中的%5.3s对于这种%m.ns格式的格式。其中m表示输出字符串的宽度,n表示左起截取字符串中的多少字符,且对齐格式为右对齐,如果字符不足则用空格补足。但是也存在特殊情况:

当字符串长度>n>m,此时m的作用不再生效。即输出左起截取字符串中的前n个字符。

n>字符串长度时,直接从头打印至尾部。

例如本题中,m==5,n==3,字符串长度<n,所以上述的打印格式应该为:打印字符串的长度5,从左截取字符串中的3个字符,由于截取的字符小于需要打印的字符,因此,用空格补齐,由于存在右对称,所以打印结果为:

computer,空格空格com

答案选择B,不过此处的答案并没有体现右对齐和补齐空格。

3.下列main()函数执行后的结果为()

int func(){  int i, j, k = 0; for(i = 0, j = -1;j = 0;i++, j++){ k++; } return k; 
} 
int main(){ cout << (func()); 

A.-1

B. 0

C.1

D.2 

在上面给出的代码中,调用了func()函数,结果打印func()函数的返回值。在func()函数的循环中,由于j==-1,因此,并不符合循环的判断条件,因此不会进入循环,所以直接返回0.。答案选择B

4.下面程序输出是什么?

#include <stdio.h> 
int main() 
{   int a=1,b=2,c=3,d=0; if(a == 1 && b++==2) if(b!=2||c--!=3) printf("%d,%d,%d\n" ,a,b,c);else  printf("%d,%d,%d\n" ,a,b,c);else  printf("%d,%d,%d\n" ,a,b,c);return 0; 
}

A.1,2,3

B. 1,3,2

C.3,2,1

D.1,3,3

在本题给出的代码中,由于if并没有搭配相应的括号,因此会有些混乱,下面将题目的格式进行一定的更改,即:

#include <stdio.h> 
int main() 
{   int a=1,b=2,c=3,d=0; if(a == 1 && b++==2) {if(b!=2||c--!=3) {printf("%d,%d,%d\n" ,a,b,c);}else  {printf("%d,%d,%d\n" ,a,b,c);}else  printf("%d,%d,%d\n" ,a,b,c);}return 0; 
}

在第一个if判断中,第一个条件a==1判断为真,第二个条件由于是后置++,即:先使用,后++,因此也满足条件。但是在判断结束后,b==3

在第二个if判断中,需要注意,此时的操作符||存在短路机制,即如果第一个条件满足,则结果直接判断为真,不再判断第二个条件,哟与b!=2为真,因此不再运行b++==2。直接进行打印,此时a,b,c的值分别是1,3,3,因此答案选择D

5.若有定义语句:

 int a=10 ; double b=3.14 ; 则表达式 'A'+a+b 值的类型是()

A.char B. int C.double D. float

针对此题目,需要注意,不同类型的变量在进行运算时,会出现自动提升的机制,即表示数据范围小的类型会自动提升到表示范围大的类型,在题目给出的类型中,'A'占用一个字节,a占用4字节,b占用8字节,因此,运算结果在最后会转换为double。因此答案选择C

6.在下面给出的数组中中,p[1][2]的值是():

int p[][4] = {{1}, {3, 2}, {4, 5, 6}, {0}};

A.1 B. 0 C.6 D.2

给出的数组是一个二维数组,其行数没有给出,列数为4,在数组中的数组中,如果给出的数没有达到4位,则会用0补齐。因此,题目中给出的二维数组的结构为:

{1,0,0,0}
{3,2,0,0}
{4,5,6,0}
{0,0,0,0}

对于二维数组,其行、列数都是从0开始算起的,因此,p[1][2]==0.,因此答案选择B

7.选择表达式 11|10 的结果(本题数值均为十进制):

A.11 B. 10 C.8 D.2

题目涉及到二进制的运算,将11转为二进制形式,其后八位为:

0000 1011

对于10,其二进制位数为:

0000 1010

对于二者的|运算,规则为二进制位数有11,全0则为0.:

11:0000 1011
10:0000 1010 运算结果:0000 1011

因此答案选择A

8.fun(21)运行结果是

 int fun(int a){ a^=(1<<5)-1; return a; 
}

A.10 B. 5 C.3 D.86

在本题目中,涉及到了两个操作符,分别是异或操作符^,以及位运算操作符>> \, \, \, <<。对于异或操作符,其运算规则为两个二进制位相异为1,相同则为0

对于本处的位操作符是左移操作符<<,其规则是右边二进制位丢弃且补0

而对于右移操作符>>,则分为算术右移和逻辑右移,对于题目,一般默认采用算术右移,即右边丢弃,左边补上符号位,负数补1,正数补0.

在本题中,1<<5,其位移后为:

移动前:0000 0001
移动后:0010 0000

移动后,此时二进制位数转换为10进制,则表示的数为32。所以,答案是变量a,即2131的异或,即:

21的二进制位:0001 0101
31的二进制位:0001 1111
异或结果:    0000 1010

所以答案选择A

9.若有定义语句:int year=1009,*p=&year;以下不能使变量 year 中的值增至 1010 的语句是

A.*p+=1;

B. (*p)++;

C.++(*p)

D. *p++

在本题目中,涉及到了操作符结合的优先顺序,在选项A中,*的优先级大于+=,因此可以增到1010。对于B,C存在括号,因此不做解释,可以增到1010.对于选项D由于后置++的优先级大于*。但是由于是后置++,因此D选项的整体运行顺序为:解引用指针,在对指针进行++,答案选择D

10.下面关于"指针"的描述不正确的是

A.当使用free释放掉一个指针内容后,指针变量的值被置为NULL

B. 32位系统下任何类型指针的长度都是4个字节

C.指针的数据类型声明的是指针实际指向内容的数据类型

D.野指针是指向未分配或者已经释放的内存地址

对于A选项,当指针被free后,指针变量的值不是NULL,而是依旧指向一块空间的地址,但是由于这块空间被释放,因此指针为野指针。

对于B选项,指针的定义,正确

对于D选项正确,此处给出避免野指针的措施,即创建指针时即使初始化,free掉指针指向的空间后将指针置空,不进行数组的越界访问

二.编程:

2.1 删除公共字符:


题目对于链接如下:
删除公共字符_牛客题霸_牛客网 (nowcoder.com)

对于本题,可以利用哈希的思想进行解决,首先创建两个string类型的对象,分别命名为str1,str2,其中,str1,str2分别用于接收第一行、第二行的输入。

在完成输入后,创建一个数组arr[256],用于统计str2中各个字符出现的次数,如果出现一个字符,则对于数组的位置置为1.

最后,从头遍历str1中的字符,如果arr[str1[i]]位置的值为0,即str1中的字符在数组中在str2中没有出现过。则输出该字符,具体代码如下:

int main()
{string str1,str2;getline(cin,str1);getline(cin,str2);int arr[256] = {0};for( size_t i = 0; i < str2.size(); i++){arr[str2[i]] = 1;}for(size_t j = 0; j < str1.size(); j++){if(arr[str1[j]] == 0){cout << str1[j];}}return 0;}


2.2 组队竞赛:

题目分析:

本题题目较长,看起来较为复杂,其实原理并不难,具体如下:
题目会给定n个队伍,每个队伍均有三名选手,对于每个选手都定义了一个水平值,为了方便表示,这里将水平值定义为value

对于一个队伍整体的水平值等于队伍中第二高的水平值。

对于题目的要求,是需要n个队伍的整体水平值达到最大。例如题目中给出的例子:1,2,5,5,5,8。最大水平值的组合应该是1,5,52,5,8.不难看出,在本题目中,最大的水平值永远无法取到。如果想要让两个队伍的水平值之和为最大。最优情况,是在每组中,均能取到所有人水平值的第二高。具体如下:
     假如对于3*3的组,其每个人的水平值为:1,2,3,4,5,6,7,8,9。对于最优的水平值上面说到了,是取总体水平值的第二高。因此,也就是8,而为了能取到8,队伍中需要一个比8大的值,一个最小的值,也就是1,9.所以第一组分组为1,8,9。同理,第二组的分组为2,6,7。第三组为3,4,5

所以,解决题目的重点有两个,一是将选手的水平值排列成升序序列,此问题比较简单,直接调用sort函数即可。

第二个问题,是如何取到第二大的值:

对于上面给出的图:蓝色方框表示需要选中的数,下面的蓝色数字表示数组的下标。对于数组的长度设为n,不难看出,蓝色方框选出的数的下标可以通过下面给出的式子表示,即:
                                n-2*(i+1) \, \, \, \, \, \, \, \, \, \, \, \, \, \, \, i==0,1,2,......

因此,代码为:

#include <iostream>
#include<vector>
#include<algorithm>
using namespace std;int main()
{vector<int> v;int n = 0;cin >> n;v.resize(3*n);for( size_t i = 0; i < 3*n; i++){cin >> v[i];}long long sum = 0;sort(v.begin(),v.end());for( size_t j = 0; j < n; j++){sum += v[v.size()-2*(j+1)];}cout << sum;return 0;}

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

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

相关文章

基于Java的校园失物招领管理系统(Vue.js+SpringBoot)

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、研究内容2.1 招领管理模块2.2 寻物管理模块2.3 系统公告模块2.4 感谢留言模块 三、界面展示3.1 登录注册3.2 招领模块3.3 寻物模块3.4 公告模块3.5 感谢留言模块3.6 系统基础模块 四、免责说明 一、摘要 1.1 项目介绍 校园失物招领…

Cyber RT 开发工具

在Cyber RT中还提供了一些工具&#xff0c;这些工具可以拓展Cyber RT功能、提高开发调试效率&#xff0c;本章主要介绍这些工具的使用。 本章内容: 1.cyber record工具的应用&#xff1b; 2.常用命令工具的使用&#xff1b; 学习收获: 1.可以通过cyber record将发布的话题消息…

因果学习篇(2)-Causal Attention for Vision-Language Tasks(文献阅读)

Causal Attention for Vision-Language Tasks 引言 这篇论文是南洋理工大学和澳大利亚莫纳什大学联合发表自2021年的CVPR顶会上的一篇文献&#xff0c;在当前流行的注意力机制中增加了因果推理算法&#xff0c;提出了一种新的注意力机制&#xff1a;因果注意力(CATT)&#xff…

AI智商排名:Claude-3首次突破100

用挪威门萨&#xff08;智商测试题&#xff09;中 35 个问题对chatGPT等人工智能进行了测试&#xff1a; ChatGPT 对ChatGPT进行了两次挪威门萨测试&#xff0c;在 35 个问题中&#xff0c;它平均答对了 13 个&#xff0c;智商估计为 85。 测试方法 每个人工智能都接受了两次…

2023第十届GIAC全球互联网架构大会:洞察未来互联网架构的革新与突破(附大会核心PPT下载)

随着互联网的迅猛发展&#xff0c;其底层架构的演进与革新成为了推动全球数字化进程的关键力量。2023年第十届GIAC全球互联网架构大会如期而至&#xff0c;汇聚了全球互联网架构领域的顶尖专家、学者、企业领袖和创新者&#xff0c;共同探讨和展望互联网架构的未来发展趋势。本…

RabbitMQ 基本介绍

RabbitMQ 基本介绍 消息模型 所有 MQ 产品从模型抽象上来说都是一样的过程&#xff1a; 消费者&#xff08;consumer&#xff09;订阅某个队列。生产者&#xff08;producer&#xff09;创建消息&#xff0c;然后发布到队列&#xff08;queue&#xff09;中&#xff0c;最后…

centos7安装maven离线安装

1、从官方网站下载maven文件包 官方下载网站&#xff1a;https://maven.apache.org/download.cgi 2、创建文件夹解压文件 将下载好的安装包&#xff0c;放到创建的目录下&#xff0c;并解压 a、创建/app/maven文件 mkdir /app/mavenb、解压文件 tar -zxvf apache-maven-…

C#使用whisper.net实现语音识别(语音转文本)

目录 介绍 效果 输出信息 项目 代码 下载 介绍 github地址&#xff1a;https://github.com/sandrohanea/whisper.net Whisper.net. Speech to text made simple using Whisper Models 模型下载地址&#xff1a;https://huggingface.co/sandrohanea/whisper.net/tree…

32、Redis 7系列:Spring Boot集成Redis

32、Redis 7系列&#xff1a;Spring Boot集成Redis 一、前言二、集成 RedisTemplate1、单机&#xff08;1&#xff09;新建项目&#xff08;2&#xff09;修改pom文件&#xff08;3&#xff09;修改yml文件&#xff08;4&#xff09;启动类&#xff08;5&#xff09;配置类&…

1.初识python

1.初识python 编程语言是用来定义计算机程序的语言&#xff0c;用来向计算机发出指令。 1.python语言是一种面向对象的解释型高级编程语言。 解释型语言&#xff1a;使用专门的解释器对源码程序逐行解释成特定平台的机器并立即执行&#xff0c;是代码在执行时才被解释器一行行…

centos7 部署kibana

先决条件参考 虚拟机部署elasticsearch集群-CSDN博客 这里使用elk101服务器安装kibana 下载rpm包(这里添加了-c参数用到wget的断点续传功能) #下载kibana-rpm包以及校验文件 wget -c https://artifacts.elastic.co/downloads/kibana/kibana-7.17.18-x86_64.rpm wget -c htt…

尤雨溪:Vue 未来展望新的一轮

十年&#xff0c;一个既漫长又短暂的时光跨度&#xff0c;对于技术世界来说&#xff0c;更是沧海桑田的瞬间。在这十年里&#xff0c;Vue.js 从无到有&#xff0c;从默默无闻到蜚声全球&#xff0c;不仅改变了前端开发的面貌&#xff0c;更成为了无数开发者手中的得力工具。 在…

设计模式之策略模式实践

设计模式之策略模式实践 先了解一下策略模式的定义是什么&#xff1f;解决什么问题 策略模式是一种行为设计模式&#xff0c;它定义了一系列算法&#xff0c;将每个算法封装成一个类&#xff0c;并使它们可以互相替换。策略模式允许客户端在运行时从可互换的算法中选择一个&a…

【论文精读】TextDiffuser-2:释放语言模型用于文本渲染的力量

文章目录 一、前言二、摘要三、方法&#xff08;一&#xff09;TextDiffuser-2模型的整体架构&#xff08;二&#xff09;语言模型M1将用户提示转换为语言格式的布局&#xff08;三&#xff09;将提示和布局结合到扩散模型内的可训练语言模型M2中进行编码以生成图像 四、实验&a…

基于单片机的数字温度计设计

目 录 摘 要 I Abstract II 引 言 1 1 整体方案设计 3 1.1 主控芯片类型选择 3 1.2 测温电路选择 3 1.3 系统总体方案 4 2 系统的硬件电路设计 5 2.1 单片机系统设计 5 2.2 显示模块设计 8 2.3 温度读取电路的设计 10 3 系统软件设计 13 3.1 软件开发环境的介绍 13 3.2 系统重…

ubuntu_定制文件系统[2]-清理日志log

1.问题现象 系统长时间运行, 产生大量的系统日志 ubuntu/debian 系统日志如下 /var/log$ du -sh * 31M syslog # syslog日志 61M syslog.1 2.5G journal/ # systemd service日志 当日志文件过大, 硬盘空间占用100%时, 导致各种异常 命令按tab补全无响应服务/进程启动异常服务…

Docker之若依项目部署

目录 一、搭建项目的局域网 1.1搭建局域网 1.2查看局域网 1.3注意&#xff1a;要关闭防火墙&#xff0c;关闭后要重启docker 二、redis安装 2.1创建目录 2.2修改redis.conf文件 三、MySQL安装 3.1安装 3.2设置远程连接 3.3创建数据库 四、若依后端项目搭建 4.1创建…

挑战杯 基于深度学习的植物识别算法 - cnn opencv python

文章目录 0 前言1 课题背景2 具体实现3 数据收集和处理3 MobileNetV2网络4 损失函数softmax 交叉熵4.1 softmax函数4.2 交叉熵损失函数 5 优化器SGD6 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; **基于深度学习的植物识别算法 ** …

Xilinx高级调试方法--远程调试

Xilinx高级调试方法--远程调试 1 虚拟电缆调试2 FPGA设计2.1 扩展配置接口 3 PCIe-XVC驱动3.1 PCIe-XVC驱动3.2 XVC-Server 4 Vivado Design Suite4.1 同一台主机4.2 不同主机 本文主要介绍Xilinx的一些高级调试方法&#xff0c;以及如何使用Xilinx的相关IP。 1 虚拟电缆调试 …

Java基础知识点

Java基础知识点 1.方法重载和重写的区别 方法重载&#xff1a; 同一个类中的方法&#xff0c;方法名相同&#xff0c;返回值可以相同可以不同&#xff0c;参数列表必须不同发生在编译期&#xff0c;在编译期确定执行哪个方法 方法重写&#xff1a; 指的是子类重新定义父类…