【c语言测试】
1. C语言中,逻辑“真”等价于( )
题目分析:
“逻辑真”在C语言中通常指的是非零数。
- A. 大于零的数
- B. 大于零的整数
- C. 非零的数 (正确答案)
- D. 非零的整数
正确答案:C
2. 若定义了数组 int a[3][4];,则对a数组元素的非法引用是( )
题目分析:
题目考查的是二维数组的访问,定义的时候a[3][4] 表示有3行4列, 但是使用的时候是从数组坐标0开始的a[0][0] 到 a[2][3]。任何超出这个范围的引用都是非法的。
- A.
a[0][2*1] - B.
a[1][3] - C.
a[4-2][0] - D.
a[0][4](正确答案)
正确答案:D
3. 执行C语言语句 “for(i=1; i++<4; );” 后,变量i的值是( )
题目分析:
这个for循环从 i=1 开始,条件是 i++<4,i先比较再自增,直到i变为5时,循环终止。
- A. 2
- B. 3
- C. 4
- D. 5 (正确答案)
正确答案:D
4. 执行下面的一段C程序后,变量x的值为( )。
char x = 200;
int a = 300;
BOOL flag;
int value1, value2;
value1 = 200;
value2 = 300;
if (flag && ((value1 = value2) == 200)) {x = x + a;
}
题目分析:
-
x是char类型,初始值为200; -
分解这个表达式:(flag && ((value1 = value2) == 200))
-
((value1 = value2) == 200)中,value1先被value2赋值为300,然后value再与200进行对比,如果等于为true(1),不等于为false(0).这里表达式结果为flase(0)
-
然后
flag未被赋值,默认为0,flag与导致if条件不成立,不执行x = x + a;; -
所以
x保持初始值。 -
A. 0
-
B. 200 (正确答案)
-
C. 300
-
D. 500
正确答案:B
5. 执行下列程序时从键盘上输入5,则输出结果是( )
#include <stdio.h>
main()
{int x;scanf("%d",&x);if(x++>=5) printf("%d\n", x);else printf("%d\n", x--);
}
题目分析:
输入为5时,x++先进行比较再自增,因此条件 x++ >= 5 为真,执行 printf("%d\n", x);,x–先输出6后自减。
- A. 7
- B. 6 (正确答案)
- C. 5
- D. 4
正确答案:B
6. 以下C语言程序的输出结果是( )。
struct s
{int x,y;
} data[2] = {10,100,20,200};
main()
{struct s *p=data;p++;printf("%d\n",++(p->x));
}
- A. 10
- B. 11
- C. 20
- D. 21 (正确答案)
题目分析:
-
初始化:
data[0]初始化为{10, 100}data[1]初始化为{20, 200}
-
指针
p初始状态:p -> data[0] (10, 100):
+--------------------+| data ||--------------------|| data[0] | ⬅p (指向 data[0])| +---+---+ || | 10|100| || +---+---+ || ||--------------------|| data[1] || +---+---+ || | 20|200| || +---+---+ |+--------------------+
- 指针自增:
p++,现在p指向data[1](20, 200):
+--------------------+| data ||--------------------|| data[0] | | +---+---+ || | 10|100| || +---+---+ || ||--------------------|| data[1] | ⬅p (指向 data[1])| +---+---+ || | 20|200| || +---+---+ |+--------------------+
- 访问和自增
++(p->x),访问 p->x(data[1].x)并进行自增操作:p指向data[1]后,p->x的值为20;++(p->x)使其值变为21,最终输出21。
+--------------------+| data ||--------------------|| data[0] | | +---+---+ || | 10|100| || +---+---+ || ||--------------------|| data[1] | ⬅p (指向 data[1])| +---+---+ | // data[1].x 从 20 变为 21| | 21|200| || +---+---+ |+--------------------+
正确答案:D
7. 阅读下面程序,该程序运行后的输出结果是( )。
#include <stdio.h>
int a;
int f(int);
main()
{int a=0;printf("%d\n",f(5));printf("%d\n",f(10));
}
int f(int m)
{static int a=0;int b=0;a+=m; b+=5;return b;
}
题目分析:
-
函数
f中的静态变量a的值累加,函数结束不会被清零; -
b是局部变量,每次调用后都被初始化为0,最终返回5; -
输出为两次
5。 -
A. 5, 15
-
B. 5, 10 (正确答案)
-
C. 0, 0
-
D. 0, 10
正确答案:B
第8题
阅读以下程序,并选择符合要求的输出结果。
char [] = " ";
* = ;
= ;
() = _____
() = _____
() = _____
选项:
- (),,
- (),,
- (),,
根据题目描述,无法确定具体的输出结果,因为缺少关键信息。请提供完整的程序或更多的上下文信息以便准确回答。
第9题
阅读以下程序片段,并选择符合要求的输出结果。
void foo(void)
{unsigned int a = 6;int b = -20;(a+b > 6)? puts("> 6"): puts("<= 6");
}
选项:
- (A) >6
- (B) <=6
- © 不确定
解答:
unsigned int a = 6;定义了a为无符号整数,值为 6。int b = -20;定义了b为有符号整数,值为 -20。- 计算
a + b得到-14。 - 因为
a + b是负数,所以a + b < 6。 - 输出
"<= 6"。
答案:(B) <=6
第10题
下面的程序(a)和程序(b)运行后,y 和 c 的值分别是。
程序(a):
#define f(x) x*x
main()
{int x=2; float y;y=x/f(x);
}
程序(b):
#define f(x) x/x
main()
{int x=2; float y;y=x/f(x);
}
解答:
-
程序(a):
#define f(x) x*xy = x / f(x)展开宏替换后为y = 2 / (2*2),即y = 2 / 4,结果为0.5。
-
程序(b):
#define f(x) x/xy = x / f(x)展开宏替换后为y = 2 / (2/2),即y = 2 / 1,结果为2。
答案:
- 程序(a)运行后,y 的值为
0.5。 - 程序(b)运行后,y 的值为
2。
请确认是否正确理解了题目内容,如有不同意见或补充,请告知。
好的,我来解答一下这张试卷上的题目。
选择题部分
- seldom
- by themselves
- alone
简答题部分
- 请问
#include <filename.h>和#include "filename.h"有什么区别?
#include <filename.h>: 表示只在标准库里面去查找这个头文件。#include "filename.h": 表示先在用户所在的目录路径去查找,找不到的话再去标准库里面去查找。
- 请写出 char *p 与 “零值” 比较的 if 语句。
if (*p == '\0') {// do something
}
- 写一个“标准”宏 MIN,这个宏输入两个参数并返回较小的一个。
#define MIN(X,Y) ((X)<(Y)?(X):(Y))
- 请简述以下两个 for 循环的优点和缺点。
-
第一个 for 循环:
- 优点:当 condition 条件改变时,会改变 DoSomething 进行 DoOtherThing。
- 缺点:需要额外的条件判断,代码可能更复杂。
-
第二个 for 循环:
- 优点:不需要额外的条件判断,代码简洁。
- 缺点:如果 condition 改变,可能会导致 DoSomething 和 DoOtherThing 都被执行,效率较低。
希望这些解答对您有帮助!如果有其他问题,请随时告诉我。
好的,我来解答一下这张试卷上的题目。
第20题
请说明 Heap 与 stack 的区别。(5分)
- Heap: 属于堆空间,需要通过手动申请和释放,如使用 malloc 或 calloc 分配一块空间后,没有释放,那么这块空间可以用动态存储结束。
- Stack: 属于栈空间,用来存放局部变量、函数调用时所需的临时空间,它是由编译器自动分配和释放。
第21题
编写 strcpy 函数(15分)
已知 strcpy 函数的原型是 char *strcpy(char *strDest, const char *strSrc);
其中 strDest 是目的字符串,strSrc 是源字符串。
int def_copy(char *strDest, const char *strSrc)
{while(*strSrc != '\0'){*strDest = *strSrc;strDest++;strSrc++;}return 0;
}
第22题
请用 C 语言实现:将二维数组行列元素互换,存到另一个数组中。(15分)
数据结构,函数原型可自行定义。
void swap(int arr[][N], int line, int tmp[][N])
{for (int i = 0; i < line; i++){for (int j = 0; j < N; j++){tmp[i][j] = arr[j][i];}}
}
第23题
请编写一个 C 函数,该函数给出一个字节中(输入参数)被置 1 的位的个数。(15分)
函数原型是 unsigned short BitNum(const unsigned char input)
unsigned short BitNum(const unsigned char input)
{int cnt = 0;for (int i = 0; i < 8; i++){if (input & 1)cnt++;input >>= 1;}return cnt;
}
希望这些解答对你有所帮助!如果有任何疑问,请随时提问。
相关文章:
【c语言测试】
1. C语言中,逻辑“真”等价于( ) 题目分析: “逻辑真”在C语言中通常指的是非零数。 A. 大于零的数B. 大于零的整数C. 非零的数 (正确答案)D. 非零的整数 正确答案:C 2. 若定义了数组 int a[3][4];,则对…...
一种将树莓派打造为游戏机的方法——Lakka
什么是Lakka? Lakka是一款Linux发行版,轻量级的,可将小型计算机转变为一台复古游戏机。 图1-Lakka官网,见参考链接[1] Lakka是RetroArch和libretro生态系统下的官方操作系统,前者RetroArch是模拟器、游戏引擎和媒体播…...
如何在 MySQL 中创建一个完整的数据库备份?
在MySQL数据库中创建一个完整的数据库备份通常不是通过编程语言直接实现的,而是借助MySQL提供的命令行工具mysqldump来完成。 作为Java开发者,我们可以编写脚本来调用这些工具,从而实现自动化备份。 下面我们将详细介绍如何使用Java来调度m…...
京准电钟HR-901GB双GPS北斗卫星时钟服务器
京准电钟HR-901GB双GPS北斗卫星时钟服务器 京准电钟HR-901GB双GPS北斗卫星时钟服务器 作为国家电力系统最重要的设备之一,卫星时间同步装置随着电力行业的发展不断有了新的要求,从单纯的具备时间数据输出能力,发展到装置状态信息上送、对用时设备的对时质量进行监测,确保站点内…...
uniapp使用websocket
后端java websoket中的 onOpen 中。依赖注入为null 引用:https://blog.csdn.net/qq_63431773/article/details/132389555 https://blog.csdn.net/weixin_43961117/article/details/123989515 https://cloud.tencent.com/developer/article/2107954 https://blog.c…...
基于Pycharm和Django模型技术的数据迁移
1.配置数据库 在trip_server/settings.py中修改配置: 其格式可访问官网:Settings | Django documentation | Django 1.1 配置数据库 文件地址:trip_server/settings.py 配置前需要创建(NaviCat)个人数据库 "…...
乐尚代驾-----Day10(订单三)
hi UU 们!!!我又来跟辛辣!感谢你们的观看,话不多说!~ 司机到达代驾终点,代驾结束了。结束代驾之后, – 获取额外费用(高速费、停车费等) – 计算订单实际里程…...
105. 聚光源SpotLight
入门部分给大家介绍过平行光DirectionalLight、点光源PointLight、环境光AmbientLight,下面给大家介绍一个新的光源对象,也就是聚光源SpotLight。 创建聚光源SpotLight 聚光源可以认为是一个沿着特定方会逐渐发散的光源,照射范围在三维空间中构成一个圆…...
系统接口权限拦截器,获取用户信息存储
UserInfo 类 这是一个表示用户信息的 Java 类,使用了 Lombok 注解来简化代码编写。 import lombok.Data; import lombok.EqualsAndHashCode; import lombok.ToString;import java.io.Serializable; import java.util.List;Data ToString EqualsAndHashCode public…...
Chromium HTML5 新的 Input 类型color 对应c++
一、Input 类型: color color 类型用在input字段主要用于选取颜色,如下所示: <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>菜鸟教程(runoob.com)</title> </head> <body&…...
问:SQL中的通用函数及用法?
SQL函数是在SQL语句中使用的预定义的计算工具,可以对一列数据进行操作并返回一个单一的结果。这些函数大致可以分为两类:Aggregate函数和Scalar函数。Aggregate函数对一组值执行计算,并返回单个值,如求和、平均值、最大值和最小值…...
.NET Core WebApi第6讲:WebApi的前端怎么派人去拿数据?(区别MVC)
一、前端界面小基础 head:引入CSS, 引入JS是写在head里面。 body:眼睛肉眼能看到的用户展示的界面是写在body里面。 二、前端怎么派人去拿数据? 1、MVC:前后端不分离,MVC相比WebApi只是多了一个views的文件夹 &am…...
Chromium HTML5 新的 Input 类型date 对应c++
一、Input 类型: date date 类型允许你从一个日期选择器选择一个日期。 <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>test</title> </head> <body><form action"demo-form.php"…...
ZooKeeper的应用场景:深入探讨分布式系统中的多样化应用
Apache ZooKeeper 是一个开源的分布式协调服务,专为确保分布式系统中的高可用性和一致性而设计。在现代分布式应用程序中,协调、同步和管理是实现高效和可靠服务的关键部分,而 ZooKeeper 通过提供这些基础功能而成为许多分布式系统不可或缺的…...
【Vue3】第四篇
Vue3学习第四篇 01. 插槽Slots02. 插槽Slots(续集)03. 插槽Slots(再续集)04. 组件生命周期05. 生命周期应用06. 动态组件07. 组件保持存活08. 异步组件09. 依赖注入10. Vue应用 01. 插槽Slots 模板内容:html结构&#…...
Chromium HTML5 新的 Input 类型tel对应c++
一、Input 类型: tel <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>test</title> </head> <body><form action"demo-form.php">电话号码: <input type"tel" name…...
JVM—类加载器、双亲委派机制
目录 什么是类加载器 类加载器的分类 Bootstrap启动类加载器 通过启动类加载器加载用户jar包 Extension扩展类加载器和Application应用程序类加载器 通过扩展类加载器加载用户jar包 双亲委派机制 打破双亲委派机制 自定义类加载器 线程上下文类加载器 Osgi框架的类加…...
笔试题 求空格分割的英文句子中,最大单词长度。
求空格分割的英文句子中,最大单词长度。例如:“this is a word”,最大单词长度为4。要求:不能用 split 函数对字符串进行切分,算法复杂度为o(n) public class MaxWordLength { public static int maxWordLength(String sentence) { if (se…...
【笔记】大模型长度外推技术 NTK-Aware Scaled RoPE
NTK-Aware Scaled RoPE 正弦编码(Sinusoidal)旋转位置编码RoPE编码步骤:旋转位置编码的优势 NTK-Aware Scaled RoPE直接外推线性内插进制转换高频外推、低频内插的理解位置编码 总结参考: 长度外推技术是自然语言处理(NLP)领域中&…...
前端 eslint 配置,以及在git提交之前自动format
目录 1、配置eslint步骤 1、eslint安装配置步骤 2、配置scripts步骤 3、测试eslint 2、配置git-hook1、安装环境2、最终效果 众所周知,前端项目可以在报很多error的情况下运行。但是良好的代码规范仍然有利于项目的开发维护,这里提供我的规范,…...
Image-to-Video镜像使用技巧:提示词怎么写?参数怎么调?
Image-to-Video镜像使用技巧:提示词怎么写?参数怎么调? 1. 快速上手Image-to-Video镜像 Image-to-Video图像转视频生成器是一款基于I2VGen-XL模型的实用工具,能够将静态图片转化为动态视频。这个由科哥二次开发的镜像已经预装了…...
嵌入式C语言变量初始化技术详解
## 1. 嵌入式C语言变量初始化技术详解### 1.1 初始化的重要性与基本原则在嵌入式系统开发中,变量初始化是防止未定义行为的关键步骤。由于嵌入式编译器特性的差异,未初始化的变量可能包含随机值,导致系统出现不可预测的行为。根据变量类型的不…...
跨平台终端工具cmatrix:打造震撼的数字雨可视化效果
跨平台终端工具cmatrix:打造震撼的数字雨可视化效果 【免费下载链接】cmatrix Terminal based "The Matrix" like implementation 项目地址: https://gitcode.com/gh_mirrors/cm/cmatrix 你是否曾幻想过在自己的终端中重现《黑客帝国》里令人着迷的…...
告别Transformer?手把手复现SegNeXt语义分割模型(附PyTorch代码)
从零实现SegNeXt:用纯卷积架构挑战Transformer的语义分割霸主地位 在计算机视觉领域,语义分割技术正经历着一场静默的革命。当大多数研究者将目光聚焦于Transformer架构时,SegNeXt却用纯粹的卷积神经网络(CNN)设计刷新…...
FireRedASR-AED-L在软件测试中的应用:语音交互功能自动化测试
FireRedASR-AED-L在软件测试中的应用:语音交互功能自动化测试 你有没有想过,那些能听懂你说话的手机应用、智能音箱或者车载系统,它们的“听力”到底准不准?开发团队是怎么确保你每次说“播放音乐”或者“导航回家”,…...
BiliRoamingX集成开发:Android 14兼容性优化与高级模块注入技术解析
BiliRoamingX集成开发:Android 14兼容性优化与高级模块注入技术解析 【免费下载链接】BiliRoamingX-integrations BiliRoamingX integrations powered by revanced. 项目地址: https://gitcode.com/gh_mirrors/bi/BiliRoamingX-integrations BiliRoamingX作为…...
安卓玩机神器:无需Root的“搞机工具箱”全功能解析与实战指南
1. 安卓玩机新选择:搞机工具箱为何成为神器? 最近在折腾安卓手机时,发现了一个宝藏工具——搞机工具箱。作为一个长期和安卓系统打交道的玩家,我试过各种需要Root权限的工具,但这款软件最让我惊喜的是它完全不需要Root…...
如何高效使用iOS推送调试工具:SmartPush完整操作指南
如何高效使用iOS推送调试工具:SmartPush完整操作指南 【免费下载链接】SmartPush SmartPush,一款iOS苹果远程推送测试程序,Mac OS下的APNS工具APP,iOS Push Notification Debug App 项目地址: https://gitcode.com/gh_mirrors/smar/SmartPush SmartPush是一款…...
【QT】Layout布局间隙优化全攻略(参数调整与实战技巧)
1. 为什么你的QT界面总有"迷之缝隙"? 每次用QT做界面开发时,最让我抓狂的就是那些莫名其妙出现的空白间隙。明明已经按照设计稿精确设置了控件尺寸,但运行起来总会出现几个像素的偏差。后来我发现,这些间隙主要来自三个…...
音乐解密技术探秘:从加密困境到跨平台解决方案
音乐解密技术探秘:从加密困境到跨平台解决方案 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库: 1. https://github.com/unlock-music/unlock-music ;2. https://git.unlock-music.dev/um/web 项目地址: https://gitc…...
