当前位置: 首页 > news >正文

【C刷题】day2

一、选择题

1、以下程序段的输出结果是( )

#include<stdio.h>
int main()
{
char s[] = "\\123456\123456\t";
printf("%d\n", strlen(s));
return 0;
}

A: 12 B: 13 C: 16 D: 以上都不对
【答案】:

A

【解析】:

考点:转义字符

\\表示反斜杠,取消转义的作用

\123表示八进制的123

\t表示水平制表符,相当于Tab键

这些都是算一个字符,其他都是单独一个为一个字符,故为12个


2、若有以下程序,则运行后的输出结果是()

#include <stdio.h>
#define N 2
#define M N + 1
#define NUM (M + 1) * M / 2
int main()
{
printf("%d\n", NUM);
return 0;
}

A: 4 B: 8 C: 9 D: 6
【答案】:

B

【解析】:

考点:define宏定义只是简单的替换

(1)先把M进行替换得到(N+1+1)*N+1/2(M换成N+1不用加括号,直接替换就好)

(2)再把N进行替换,(2+1+1)*2+1/2得到就是8.5

(3)以整形的形式进行打印,取整数部分就是8


3、如下函数的 f(1) 的值为( )

int f(int n)
{
static int i = 1;
if(n >= 5)
return n;
n = n + i;
i++;
return f(n);
}

A: 5 B: 6 C: 7 D: 8
【答案】:

C

【解析】:

考点:

static修饰局部变量改变了变量的周期(让静态局部变量出了作用域依然存在,知道程序结束,生命周期才停止)


4、下面3段程序代码的效果一样吗( )

int b;
(1)const int *a = &b;
(2)int const *a = &b;
(3)int *const a = &b;

A: (2)=(3) B: (1)=(2) C: 都不一样 D: 都一样
【答案】:

B

【解析】:

考点:指针常量和常量指针

重要区别:*的位置

我们以*为分界线,如果const在*左边,那么就是常量指针(指针指向的是常量);

如果const在*右边,那么就是指针常量(指针是个常量)

1.常量指针:指针指向的内容是常量(const只存在于指针指向的过程中,而与变量本身是否被const修饰无关)

const  int *n;

int  const *n;

注意两点

(1)常量指针的意思是不能通过指针解引用改变变量(b)的值,但是可以通过其他引用来改变变量(b)的值

int b=5;
const int *a=&b;
b=6;

(2) 常量指针可以改变指向,常量指针可以指向其他的地址

int a = 5;
int b = 6;
const int* n = &a;
n = &b;

2.指针常量:指针本身是个常量,不能指向其他的地址

int * const n;

 注意:

指针常量指向的地址不能改变,但是地址中保存的值是可以改变的,数据可以通过其他指向改变地址的指针来修改

int a = 5;
int* p = &a;
int* const n = &a;
*p = 8;//通过p指针来改变a的值

5、对于下面的说法,正确的是( )

A: 对于 struct X{short s;int i;char c;},sizeof(X)等于sizeof(s) + sizeof(i) + sizeof(c)

B: 对于某个double变量 a,可以使用 a == 0.0 来判断其是否为零

C: 初始化方式 char a[14] = "Hello, world!"; 和char a[14]; a = "Hello, world!";的效果相同

D: 以上说法都不对

【答案】:

D

【解析】:

A.没有考虑内存对齐

B.考察浮点型的比较,由于浮点型存在误差,不能直接判断两个数是否相等,通常采用比较两个数差的绝对值是否小于一个很小的数,作为误差

C.第二种的a代表首元素的地址,地址是常量不可以改变


二、编程题

1.尼科彻斯定理

【参考答案】:

通过数学规律找到要打印的第一个数,第一个数就是m*m-m+2*i+1

注意最后一个数不用打印+,所以要特殊考虑

#include <stdio.h>
int main() 
{int m=0;int count=0;//输入scanf("%d",&m);//输出for(int i=0;i<m;i++){if(i!=m-1)printf("%d+",m*m-m+2*i+1);//最后一个没+elseprintf("%d",m*m-m+2*i+1);}return 0;
}

2. 等差数列

【参考答案】:

 就是套数学公式,Sn=a1*n+n*(n-1)*d/2

#include <stdio.h>
int main()
{int n=0;//输入scanf("%d",&n);//输出printf("%d",2*n+n*(n-1)*3/2);
}

http://www.lryc.cn/news/166689.html

相关文章:

  • Apollo源码安装的问题及解决方法
  • Flutter 挖孔屏的状态栏占用问题怎么解决,横屏后去掉了状态栏,还是会有一块黑色的竖条
  • Layui快速入门之第九节 表格事件的使用
  • [2023.09.14]: Rust的条件编译
  • 数据清洗:数据挖掘的前期准备工作
  • 基于FPGA的图像sobel锐化实现,包括tb测试文件和MATLAB辅助验证
  • HDMI 直通 ILA 调试实验
  • 基于Qt4开发曲线绘制交互软件Plotter
  • 数据分享|R语言逻辑回归、Naive Bayes贝叶斯、决策树、随机森林算法预测心脏病...
  • 【深度学习】 Python 和 NumPy 系列教程(十五):Matplotlib详解:2、3d绘图类型(1):线框图(Wireframe Plot)
  • 阿里云CDN缓存配置及优化-oss绑定CDN缓存自动刷新功能
  • 气象站有什么用?有哪些类型
  • 【深度学习】卷积神经网络(LeNet)
  • 什么是数据仓库,解释数据仓库的结构和ETL过程
  • 无线通信网络
  • 使用ElementPlus实现内嵌表格和内嵌分页
  • flex弹性盒模型与阿里图标的使用
  • linux 应用中offsetof ()是个啥?
  • ununtu中vim的使用
  • SqlServer在尝试加载程序集 ID 65917 时 Microsoft .NET Framework 出错。服务器可能资源不足,或者不信任该程序集
  • Discourse 如何下载备份并恢复本地数据库
  • 激光焊接汽车PP塑料配件透光率测试仪
  • Android面试题汇总(二)
  • 最新模块化设计小程序系统源码完整版:开源可二开,支持DIY
  • edge扩展下载出现Download interrupted
  • Dokcer搭建Apache Guacamole堡垒机
  • 【Spring Boot自动装配】
  • windows彻底卸载unity
  • Java项目-苍穹外卖-Day10-SpirngTask及WebSocket
  • Spring IOC 容器:掌握 Spring 的核心技术