C语言入门必做踩坑题《篇三》

Posted 跳动的bit

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言入门必做踩坑题《篇三》相关的知识,希望对你有一定的参考价值。

第1题

🎗设有定义 char *p[ ] = {“Shanghai”, Beijing", “Hongkong”}; 则结果为 j 字符的表达式是 ( )

A. *p[1] + 3

B. *(p[1] + 3)

C. *(p[3] + 1)

D. p[3][1]

📝 分析:

此题是对指针数组的考察,对于上面的定义我们可以画出如下关系图

对于这段代码必须得理解这张图,否则你对这个代码的理解是有问题的,此外还需要了解运算符之间的优先级

所以选择 B 选项

第2题

🎗执行以下函数后, i 的值是 ( )

int f(int x)
{
	return ((x > 2) ? x * f(x - 1) : 3);
}
int i;
i = f(f(2));

A. 30

B. 无限递归

C. 9

D. 2160

📝 分析:


所以选择 C 选项

第3题

🎗在 int p[ ][4] = { {1}, {3, 2}, {4, 5, 6}, {0} }; 中,p[1][2] 的值是 ( )

A. 1

B. 0

C. 6

D. 2

📝 分析:

此题是对二维数组的考查

对于二维数组的不完全初始化会主动赋值 0

所以选择 B 选项

第4题

🎗设有以下宏定义,则执行语句 z = 2 * (N + Y( 5 + 1))后,z 的值是 ( )

#define N 3+1
#define Y(n) ((N+1)*n)

A. 60

B. 190

C. 248

D. 以上全错

📝 分析:

    ❗ define替换规则 ❕

      在程序扩展 #define 定义符号和宏时,需要涉及以下几个步骤

      1️⃣ 在调用宏时,首先对参数进行检查,看看是否包含任何由 #define 定义的符号。如果是,它们优先被替换

      2️⃣ 替换文本随后被插入到程序中原来文本的位置。对于宏,参数名被它们的值替换

      3️⃣ 最后,再次对结果文件进行扫描,看看它是否包含任何由 #define 定义的符号。如果是,就要重复上述过程

    ⚠ 注意:

      ▶ 宏参数和 #define 定义中可以出现其它 #define 定义的常量。
        但是对于宏,不能出现递归,因为宏只做简单的文本替换,且只替换一次

      ▶ 当预处理器搜索 #define 定义的符号时,字符串常量的内容并不被搜索

    ❗ 代码步骤如下 ❕

所以选择 A 选项

第5题

🎗char a; int b; float c; double d; 则表达式 a * b + d - c 值的类型是 ( )

A. float

B. int

C. char

D. double

📝 分析:

    ❗ 算术转换 ❕

      如果某个操作符的各个操作数属于不同的类型,那么除非其中一个操作数转换为另一个操作数的类型,否则操作就无法进行。
      下面的层次体系称为寻常算术转换

      long double
      double
      float
      unsigned long int
      long int
      unsigned int
      int

      如果某个操作数的类型在上面这个列表中排名较低,那么首先要转换为另外一个操作数的类型后执行运算
      低字节 -> 高字节 (如果是相同字节的就向精度更高的转换)

所以选择 D 选项

第6题

🎗编程题<难度系数⭐>

📝 题述:

    Fibonacci 数列是这样定义的:
    F[0] = 0
    F[1] = 1
    for each i ≥ 2: F[i] = F[i-1] + F[i-2]
    因此,Fibonacci 数列就形如:0, 1, 1, 2, 3, 5, 8, 13, …,在 Fibonacci 数列中的数我们称为 Fibonacci 数。
    给你一个 N,你想让其变为一个 Fibonacci 数,每一步你可以把当前数字 X 变为 X - 1 或者 X + 1 ,现在给
    你一个数 N 求最少需要多少步可以变为 Fibonacci 数。

🍳 输入描述:

    输入为一个正整数 N(1 ≤ N ≤ 1,000,000)

🍳 输出描述:

    输出一个最小的步数变为 Fibonacci 数

💨 示例:

    输入,15

    输入,2

🧷 平台:Visual studio 2017 && windows

🔑 核心思想:

牛客网原题

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<math.h>
int main()
{
	int n = 0;
	scanf("%d", &n);
	int f1 = 0;
	int f2 = 1;
	int f3 = 0;
	while(1)
	{
		if(n == f2)
		{
			printf("%d\\n", 0);
			break;
		}
		else if(n < f2)
		{
			if(abs(f1-n) < abs(f2-n))
			{
				printf("%d\\n", abs(f1-n));
				break;
			}
			else
			{
				printf("%d\\n", abs(f2-n));
				break;
			}	
		}
		//说明n不在f1和f2的那个区间内,还需要迭代Fib数
		f3 = f1 + f2;
		f1 = f2;
		f2 = f3;
	}
	return 0;
}

第7题

🎗编程题 <难度系数⭐⭐>

📝 题述:

    请实现一个函数,将一个字符串中的每个空格替换成 “%20” 。
    例如,当字符串为 We Are Happy. 则经过替换之后的字符串为 We%20Are%20Happy。

🧷 平台:Visual studio 2017 && windows

🔑 核心思想:


    ❓ 无厘头 ❔

      相信肯定会有人觉得这道题很奇怪,但其实这道题并不奇怪。

      当我们去百度搜索关键字 “无 厘 头” 时

      发现上面的链接使用 “%20” 替换了空格

    ❓ 为什么会空格会替换成 %20 ❔

      豌豆在网上查询了下,大多数是这样说的:

      W3C标准规定,URL查询参数中空格都会被编成加号+;而在 RFC 2396 中 URI 里的保留字符都需转义成 %HH 格式

      当然也可以理解空格的 ASCII 码是 32,对应的十六进制是 20

      行哒!这里就不扯远了

牛客网原题

#include<stdio.h>
#include<string.h>

void ReplaceSpace(char* str, int length)
{
	//1.计算空格的个数
	int i = 0;
	int spcount = 0;
	for (i = 0; i < length; i++)
	{
		if (str[i] == ' ')
			spcount++;
	}
	//2.计算替换空格后新的长度和最后的位置
	int newlengh = length + spcount * 2;
	int pos = newlengh - 1;
	//3.从后往前填充
	for (i = length - 1; i >= 0; i--)
	{
		//空格
		if (str[i] == ' ')
		{
			str[pos--] = '0';
			str[pos--] = '2';
			str[pos--] = '%';
		}
		//非空格
		else
		{
			str[pos--] = str[i];
		}
	}
}
int main()
{
	char arr[20] = "We Are Happy.";
	ReplaceSpace(arr, strlen(arr));
	printf("%s\\n", arr);
	return 0;
}

以上是关于C语言入门必做踩坑题《篇三》的主要内容,如果未能解决你的问题,请参考以下文章

C语言入门必做踩坑题《篇七》

C语言入门必做踩坑题《篇七》

C语言入门必做踩坑题《篇一》

C语言入门必做踩坑题《篇一》

C语言入门必做踩坑题《篇六》

C语言入门必做踩坑题《篇六》