2月26日做题总结(C/C++真题)

        今天是2024年2月16日,新学期开学第一天。在大三这个重要阶段,我决定参加24年秋招。在准备项目的同时,也先做一些入门的笔试题吧,慢慢积累。如果你也是处于这个阶段,欢迎来找我交流讨论!

        今天是做题第一天,就先从C/C++真题入手吧!(不做不知道,一做吓一跳,一做题发现自己的漏洞还是很多的。)慢慢来吧,只要坚持+努力,终会长风破浪会有时,直挂云帆济沧海!

第一题

下列定义不正确的是()

A---#define PI 3.1415926

B---#define S345

C---int max(x,y);int x,y;{}

D---static char c;

正确答案:C

解析:先讲一下C为什么错,int max(x,y);声明函数,但是形参未标示类型,所以C选项的定义是不正确的。这题的易错点是选B,其实#define S345是一个空宏定义,其作用是对函数进行标识、说明。

第二题

以下哪一句会出错?

char    *s="AAA";    //1
printf("%s",s);      //2
s[0]='B';            //3
pritf("%s",s);       //4

A---第一句

B---第二句

C---第三句

D---第四句

正确答案:C

解析:初始化指针时所创建的字符串常量被定义为只读。如果试图通过指针修改这个字符串的值,程序就会出现未定义的行为。s[0]只可读,不可写,也可以理解为指针只具有指向/寻址权限,没有修改数值权限。

第三题

设有如下定义:

struct Jan
{int   a;float b;
}c2,*p;

若有p=&c2;则对c2中的成员a的正确引用:()

A---(*p).c2.a

B---(*p).a

C---p->c2.a

D---p.c2.a

正确选项:B

解析:p是指向结构体对象c2的指针,指针引用对象用->符号。常见的有3种表达方式,如下:

第一种c2.a

第二种(*p).a

第三种p->a

第四题

下列描述,正确的一共有几个?

(1)const char *p,这是一个常量指针,p的值不可修改

(2)在64位机上,char *p=“abcdefghijk”;sizeof(p)大小为12

(3)inline会检查函数参数,所以调用开销显著大于宏

(4)重载是编译时确定的,虚函数是运行时绑定的

A---1个

B---2个

C---3个

D---4个

正确答案:A

(1)错误,const char *p中,应该是p这个字符指针所指向的值才不会发生改变。

        看到const记住一句话,左定值、右定向。举个例子,const int *p是常量指针,比如说是指向一个字符常量“abc”的指针,const在*左边,左定值,也就是说这个“abc”的内容不能被换掉,但是这个指针可以指向别的地址上。int *const p是指针常量,比如说这个p的地址是0X80000,const在*右边,右定向,也就是说这个指针是死死的指着0X80000不会改变,但这个地址上对应的内容是可以换成别的。

(2)错误,sizeof(p)的返回值是8 。这个8指的是char *这个指针类型在64位机器上的大小,而不是12 。

(3)错误,对于inline和宏的比较:内联函数比宏更安全,前者会有类型检查,后者只是代码的简单替换;inline在编译时,是把函数代码直接插入到目标代码中,通过空间换取时间来提高执行效率,不存在普遍函数的调用开销。

(4)正确,重载是编译时确定的,虚函数是运行时绑定的

第五题

若有如下说明:

int *p,m=5,n;

则下面程序段正确的是()

A---p=&n;scanf("%d",&p);

B---p=&n;scanf("%d",*p);

C---scanf("%d",&n);*p=n;

D---p=&n;*p=m;

正确答案:D

解析:因为p是指针变量,在scanf中不能再使用&p或者*p来接收键盘的输入值,应直接用p即可,所以A和B错误。而C中,*p=n是“野指针”赋值,因为p未指向某一内存单元,所以C错误。而D中,先将变量n的地址给指针变量p,然后再把m的值赋值给p所指向的内存单元,也就是赋值给n,所以D正确。

第六题

以下程序统计给定输入中每个大写字母的出现次数

void AlphabetCounting(char a[],int n)
{int count[26] = {}, i, kind = 10;for(i = 0;i < n;++i) (1);for(i = 0;i < 26;++i){if(++kind > 1) putchar(';');printf("%c=%d", (2));}
}

A---++count[a[i]-'Z'];'Z-i',count['Z'-i]

B---++count[A-a[i]];'A+i',count[i]

C---++count[i];i,count[i]

D---++count['Z'-a[i]];'Z-i',count[i]

正确答案:D

解析:在ASCII表中,大写字母对应的是65-90,小写字母对应的是97-122;本题输入设定全部都是大写,所以有两种情况。

        第一种,count[0;25]存储A-Z的个数,即count[0]存储A的个数,于是(1)++count[a[i]-'A'];(2)'A'+i,count[i];

        第二种,count[0;25]存储A-Z的个数,即count[0]存储Z的个数,于是(1)++count['Z'-a[i]];

(2)'Z'-i,count[i];

所以本题答案为D。

第七题

若有以下的定义:

int t[3][2];

t[2]能正确表示t数组某元素的地址。表述是否正确?

A---正确

B---错误

正确答案:A

解析:这道题谈一下我的理解,t[2]与&t[2][0]的值相等,但是意义却不一样。前者表示一整个一维数组的地址,而编译器一般将数组的首元素的地址默认为整个一维数组的地址,所以t[2]与&t[2][0]的值才会相等。

第八题

执行以下语句,输出结果为()

#include<stdio.h>
int main( ) 
{char *p1 = "hello";char *p2 = "world";char *p3 = "a piece of cake";char *str[] = {p1, p2, p3};printf("%c", *(str[0] + 1));
}

A---world

B---hello

C---编译时错误

D---其他选项都不正确

正确答案:D

解析:这题很有误导性,一不小心就会掉到出题人的坑里,让我们一起来看看吧!char *str[]={},str是一个数组名,数组每个元素都是char *,str[0]取得数组首元素,也就是p1指针,p1指向的是“hello”,p1指针+1前进一位指向字符e,最后输出e。注意,%c是只输出一个字符。而这题如果改为*(str+1),那输出结果就变成world了,大家要注意区分。

第九题

enum string
{    x1,    x2,    x3 = 10,    x4,    x5,    
} x;

函数外部访问x等于什么?

A---5

B---12

C---0

D---随机值

正确答案:C

解析:如果是在函数外定义,则为0(全局变量,初始化为0)。如果是函数内定义,则是随机值(局部变量,需要人初始化,否则编译时会显示变量未初始化)。

第十题

若所用变量都已正确定义,以下选项中,非法的表达式是()

A---a!=4||b==1

B---'a'%3

C---'a'=1/3

D---'A'+32

正确答案:C

解析:A选项正确,考察运算符的优先级:关系运算符>逻辑运算符;BD选项,当字符型与整型运算时会自动转换成整型,所以BD正确;C选项,‘a’是char类型,1/3是int类型。将int赋值给char属于从高向低赋值,所以错误。

        全力以赴,奔向远方!向前看吧,别烂在过去和梦里,总有一天你也会是别人翘首以盼的惊喜!

                                                                        ---送给每一位拼搏努力的追梦人

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

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

相关文章

备战蓝桥杯Day17 - 链表

链表 基本概念 链表是由一系列节点组成的元素集合。 每个节点包含两部分&#xff1a;数据域 item 、指向下一个节点的指针 next 通过节点之间的相互链接&#xff0c;形成一个链表 1. 链表的初始化 # 手动建立链表 # 链表的初始化 class Node(object):def __init__(self, …

[图论] 树上不重复权值的路径数

解题思路 整体思路&#xff0c;枚举路径上每个点&#xff0c;记录这个点 u 可以向上延伸到多远&#xff0c;如果可延伸到 x 点&#xff0c;则这个点对答案的贡献为 dep[u] - dep[x](下文的maxx) 1 为什么枚举是向上延伸&#xff1f;因为可以记录已走过路径中已有的权值&…

【k8s配置与存储--配置管理】

1、ConfigMap的配置 1.1 ConfigMap介绍 ConfigMap 是一种 API 对象&#xff0c;用来将非机密性的数据保存到键值对中。使用时&#xff0c; Pod 可以将其用作环境变量、命令行参数或者存储卷中的配置文件。 ConfigMap 将你的环境配置信息和容器镜像解耦&#xff0c;便于应用配…

STM32 I2C学习

IIC总线协议介绍 IIC&#xff1a;Inter Integrated Circuit&#xff0c;集成电路总线&#xff0c;是一种同步、串行、半双工通信总线。 同步&#xff1a;需要时钟线 串行&#xff1a;数据一位一位地发送 半双工&#xff1a;同一时间只能接受或发送&#xff0c;不能同时发送或…

【java】使用springMVC优雅的响应数据

1.抽象接口 import java.io.Serializable; public interface IResultCode extends Serializable {String getMessage(); int getCode(); } 2. 利用枚举类实现接口创建对象 public enum ResultCode implements IResultCode {SUCCESS(200, "操作成功"),FAILURE(400, &…

input框 自动获取焦点

<el-input style"width:200px" autofocus v-model"leftListname"></el-input> element-ui 的 el-input 组件的 autofocus 属性在某些情况下不能实现自动聚焦,有几个可能的原因: 1. autofocus 在移动设备上不被支持。如果是在移动设备上访问,au…

题目 1311: 数字三角形

题目描述: 示出了一个数字三角形。 请编一个程序计算从顶至底的某处的一条路 径&#xff0c;使该路径所经过的数字的总和最大。  每一步可沿左斜线向下或右斜线向下走&#xff1b;  1< 三角形行数< 25&#xff1b;  三角形中的数字为整数< 1000&#xff1b; 代码…

Redis 发布订阅详解

Redis 发布订阅 Redis 发布订阅 (pub/sub) 是一种消息通信模式&#xff1a;发送者 (pub) 发送消息&#xff0c;订阅者 (sub) 接收消息。Redis 客户端可以订阅任意数量的频道。 Redis 有两种发布订阅模式 基于频道&#xff08;Channel&#xff09;的发布订阅基于模式&#xff…

ChatGPT学习第三周

&#x1f4d6; 学习目标 ChatGPT在各行各业的应用 探索ChatGPT在不同领域&#xff08;如教育、客户服务等&#xff09;的实际应用案例。 ChatGPT的局限性和挑战 讨论ChatGPT面临的挑战&#xff0c;包括偏见、误解及其限制。 ✍️ 学习活动 学习资料 《人工智能通用大模型(…

openssl3.2 - exp - buf to bio

文章目录 openssl3.2 - exp - buf to bio概述笔记bio_get_length调用端代码函数实现bio_to_buffer END openssl3.2 - exp - buf to bio 概述 不想让程序调用openssl API时, 有文件落地的动作. 如果程序有配置文件要用, 也是自己读文件到buffer, 然后转成BIO给openssl的相关有…

Vue3学习——路由prop配置、replace

写法一 在路由中可直接写prop: true&#xff0c;即可在页面中defineProps使用 相当于&#xff08;<Detail id“1” name“2” />&#xff09;,但只能是params {path: /service,name: 服务,component: () > import(../views/Service/index)&#xff0c;props: true}…

SQLlabs46关

看看源码 最终我们的id是放到order by后面了 如果我们直接用列去排序 ?sortusername/password username&#xff1a; passward 可以看到顺序是不同的&#xff0c;当然第一列第二列第三列也可以&#xff0c;基本上都是这个原理&#xff0c;那怎么去实现注入呢&#xff0c;我…

TypeScript与JavaScript 的区别

TypeScript 与 JavaScript 的区别&#xff1a; TypeScript Microsoft 在编译期间可以检查和修复错误 强类型&#xff0c;支持静态和动态类型 将代码转换为JavaScript&#xff0c;需要编译 支持模块、泛型、接口 没有庞大的开发人员社区 .ts和.tsx JavaScript Netscape&…

本地复制文本无法在Ubuntu终端中粘贴问题

在公司&#xff0c;安装Ubuntu环境后无法粘贴。 查询并自己实践后&#xff0c;解决方法如下&#xff1a; 1. sudo apt-get autoremove open-vm-tools 2. sudo apt-get install open-vm-tools-desktop 3.重启虚拟机 又可以愉快的复制粘贴了

【GPTs分享】GPTs分享之Write For Me

Write For Me 是一个专门定制的GPT版本&#xff0c;旨在为用户提供高质量的文本内容创作服务。它适用于各种写作需求&#xff0c;从商业计划、学术文章到创意故事等。下面是从简介、主要功能、使用案例、优点和局限性几个方面对Write For Me 的详细介绍。 简介 Write For Me …

Java 学习和实践笔记(22):package(包机制)、JDK常见的包、类的导入

前面学的类&#xff0c;每创建一个类&#xff0c;在电脑上就是创建了一个对应的类文件。而package 相当于文件夹对文件的管理作用。主要用于管理类、用于解决类的重名问题。这个含义很简单。因为实际的程序&#xff0c;类可能有成千上万个&#xff0c;这样就需要把不同功能的类…

「连载」边缘计算(十九)02-22:边缘部分源码(源码分析篇)

&#xff08;接上篇&#xff09; 从启动函数Start(&#xff09;中可以看到&#xff0c;其以go routine的方式启动很多后台处理服务&#xff0c;具体如下。 1&#xff09;初始化edged的kubeClient&#xff0c;具体如下所示。 // use self defined client to replace fake kube…

JDK5.0新增线程的两种方式

本文主要是了解&#xff0c;并没有进入深入学习&#xff0c;JUC时才会深入学习 8.1新增方式一&#xff1a;实现Callable接口 ~与使用Runable相比&#xff0c;Callable功能更强大些 -- 相比run&#xff08;&#xff09;方法&#xff0c;可以有返回值 ---方法可以抛出异常 -…

LeetCode刷题--- 环形子数组的最大和

个人主页&#xff1a;元清加油_【C】,【C语言】,【数据结构与算法】-CSDN博客 个人专栏 力扣递归算法题 http://t.csdnimg.cn/yUl2I 【C】 ​​​​​​http://t.csdnimg.cn/6AbpV 数据结构与算法 ​​​http://t.csdnimg.cn/hKh2l 前言&#xff1a;这个专栏主要讲述动…

CSDN的AI创作助手

CSDN用到的AI创作助手详细介绍 CSDN&#xff08;中国软件开发者网&#xff09;是一个面向IT技术人员的综合性技术社区&#xff0c;提供技术问答、博客文章、开发工具等内容。AI创作助手是CSDN提供的一项人工智能服务&#xff0c;旨在帮助用户快速高效地创作文章。 AI创作助手基…