【C语言进阶篇】 你真的学会数组了嘛?数组笔试题万字解析(上)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 【C语言进阶篇】 你真的学会数组了嘛?数组笔试题万字解析(上)

📋 前言

  🌈hello! 各位宝子们大家好啊,数组和指针系列我们全部讲解完毕了,那么今天就来看一下数组的笔试题!

  ⛳️本章笔试题主要考察的是数组名和 &数组 的区别,看完本章相信你对数组名和 &数组又会有新的理解!

  📚本期文章收录在《C语言进阶篇》,大家有兴趣可以看看呐

  ⛺️ 欢迎铁汁们 ✔️ 点赞 👍 收藏 ⭐留言 📝!

💬 数组笔试题解析

在做数组笔试题之前我们需要明白这俩个点就可以了 数组名的意义:

  1. sizeof (数组名),这里的数组名表示整个数组,计算的是整个数组的大小。
  2. & 数组名 ,这里的数组名表示整个数组,取出的是整个数组的地址。
  3. 除此之外所有的数组名都表示首元素的地址。

💭 一维数组笔试题

int a[] = {1,2,3,4};
printf("%d\n",sizeof(a));
printf("%d\n",sizeof(a+0));
printf("%d\n",sizeof(*a));
printf("%d\n",sizeof(a+1));
printf("%d\n",sizeof(a[1]));
printf("%d\n",sizeof(&a));
printf("%d\n",sizeof(*&a));
printf("%d\n",sizeof(&a+1));
printf("%d\n",sizeof(&a[0]));
printf("%d\n",sizeof(&a[0]+1));

✅ 一维数组笔试题解析

printf(“%d\n”,sizeof(a));

这个就很直观了, sizeof (数组名),这里的数组名表示整个数组,计算的是整个数组的大小。

  • 所以printf(“%d\n”,sizeof(a));
  • 结果为16

printf(“%d\n”,sizeof(a+0));

这里大家不要被 sizeof (数组名)给迷糊了,虽然这里是数组名但他是首元素地址,因为指针单独是数组名才是整个元素的地址!

  • 既然是首元素地址,那么就是指针类型的 4 / 8个字节
  • printf(“%d\n”,sizeof(a+0));结果为 4/8

printf(“%d\n”,sizeof(*a));

首先排除 a 是整个数组的大小,因为这里还对a进行解引用了。所以这里的 a 指的是首元素的地址,那么对他进行解引用就找到数组的第一个元素,而数组的第一个元素是整形。

  • 那么printf(“%d\n”,sizeof(*a));
  • 结果为 4个字节

printf(“%d\n”,sizeof(a+1));

也是一样既然不是单纯的数组名,那么a就是首元素地址,首元素地址 +1 就第二个元素的地址。

  • 而第二个元素的地址,也是地址那么就是指针类型的
  • printf(“%d\n”,sizeof(a+1));
  • 结果为 4/8

🔥 注:这里运用了指针的运算不会的可以看看这章《指针的运算》


printf(“%d\n”,sizeof(a[1]));

这里就计算就是数组第一个元素的大小,而数组第一个元素的大小是整形的。

  • printf(“%d\n”,sizeof(a[1]));
  • 结果为 4

printf(“%d\n”,sizeof(&a));

诶这里有人就会犯迷糊了,&取地址 a 取出的是整个数组的地址就会认为是 16,而整个数组的地址也是地址。

  • 既然是地址,那么大小就是 4/8
  • printf(“%d\n”,sizeof(&a));
  • 结果为 4/8

printf(“%d\n”,sizeof(*&a));

这里其实可以有俩种方法理解:

📜方法一:

&地址取出的是整个数组的地址,但是又进行解引用了。这不就刚好抵消了。

  • sizeof(*&a) == sizeof(a)这里就整个数组的大小了
  • 所以printf(“%d\n”,sizeof(*&a));
  • 结果为 4/8

📜方法二:

&地址取出的是整个数组的地址,但是又进行解引用了之后。拿出的就是整个数组 而这个数组 int a[ ] = {1,2,3,4};是 4 个整形元素那么就 16 个字节

  • 所以printf(“%d\n”,sizeof(*&a));
  • 结果为 4/8

printf(“%d\n”,sizeof(&a+1));

这里我们取出的是整个数组的地址,但是又进行 +1 了。直接跳过整个数组加1 ,但他依旧是个地址。

  • 既然是地址,那么大小就是 4/8
  • printf(“%d\n”,sizeof(&a+1));
  • 结果为 4/8

printf(“%d\n”,sizeof(&a[0]));

这里 & 取地址操作符取得数组的一个元素的地址

  • 既然是地址,那么大小就是 4/8
  • printf(“%d\n”,sizeof(&a[0]));
  • 结果为 4/8

printf(“%d\n”,sizeof(&a[0]+1));

& 取数组的第一个元素的地址 +1 ,那不就取第素组第二个元素的地址嘛?

  • 既然是地址,那么大小就是 4/8
  • printf(“%d\n”,sizeof(&a[0]+1));
  • 结果为 4/8

✅ 一维数组笔试题验证

好了笔试题我们分析完了,下面就该来到验证环节了!看一下咱们的分析对还是不对 !

🔥 注:这里的4 或者 8 是指 在32位机器上地址长度为 4 。64位机器上地址长度为 8

📚 代码演示:

#include <stdio.h>
int main()
{
  int a[] = { 1,2,3,4 };
  printf("%d\n", sizeof(a));//16
  printf("%d\n", sizeof(a + 0));//  4或8
  printf("%d\n", sizeof(*a)); //  4
  printf("%d\n", sizeof(a + 1));//  4或8
  printf("%d\n", sizeof(a[1]));//  4
  printf("%d\n", sizeof(&a));//  4或8
  printf("%d\n", sizeof(*&a));// 16
  printf("%d\n", sizeof(&a + 1));//  4或8
  printf("%d\n", sizeof(&a[0]));//  4或8
  printf("%d\n", sizeof(&a[0] + 1));//  4或8
  return 0;
}

📑 代码结果:

💭 字符数组笔试题

char arr[] = {'a','b','c','d','e','f'};
printf("%d\n", sizeof(arr));
printf("%d\n", sizeof(arr+0));
printf("%d\n", sizeof(*arr));
printf("%d\n", sizeof(arr[1]));
printf("%d\n", sizeof(&arr));
printf("%d\n", sizeof(&arr+1));
printf("%d\n", sizeof(&arr[0]+1));
printf("%d\n", strlen(arr));
printf("%d\n", strlen(arr+0));
printf("%d\n", strlen(*arr));
printf("%d\n", strlen(arr[1]));
printf("%d\n", strlen(&arr));
printf("%d\n", strlen(&arr+1));
printf("%d\n", strlen(&arr[0]+1));

✅ 字符数组笔试题解析

printf(“%d\n”, sizeof(arr));

这个和我们前面是一样只不过变成了字符数组,但计算的仍然是整个数组的大小。

  • 所以:printf(“%d\n”, sizeof(arr));
  • 大小为 6

printf(“%d\n”, sizeof(arr+0));

arr 这里并不是只有数组名,所以arr数组名这里指的是首元素的地址,+0等于没有加所以还是首元素的地址。

  • 既然是地址,那么大小就是 4/8
  • printf(“%d\n”, sizeof(arr+0));
  • 结果为 4/8

printf(“%d\n”, sizeof(*arr));

这里 arr 是数组首元素那么对其解引用就是找到这个地址里面存放的内容,而这是个字符类型的元素所以:

  • printf(“%d\n”, sizeof(*arr));
  • 结果为 1

printf(“%d\n”, sizeof(arr[1]));

这里arr[1]是数组的第二个元素,而数组又是字符类型的所以:

  • printf(“%d\n”, sizeof(arr[1]));
  • 结果为 1

printf(“%d\n”, sizeof(&arr));

这里数组取出的是整个数组的地址所,但数组的地址也是地址。

  • 既然是地址,那么大小就是 4/8
  • printf(“%d\n”, sizeof(&arr));
  • 结果为 4/8

printf(“%d\n”, sizeof(&arr+1));

这里是取出数组整个元素的地址 +1 ,那么就数组的后一位地址。

  • 既然是地址,那么大小就是 4/8
  • printf(“%d\n”, sizeof(&arr+1));
  • 结果为 4/8

printf(“%d\n”, sizeof(&arr[0]+1));

这里取出的是字符数组第一个元素的地址,+1就指向了数组的而二个元素的地址

  • 既然是地址,那么大小就是 4/8
  • printf(“%d\n”, sizeof(&arr[0]+1));
  • 结果为 4/8

💭 字符数组笔试题解析 (strlen)

在做这些面试题之前需要知道 strlen 是干嘛的?strlen 是用来计算字符串长度的

  • 从我们给定地址一直计算到 \0 的位置
  • 找不到 \0 就会一直往后计算字符长度只到找到 \0

✅ 字符数组(strlen)的考察

printf(“%d\n”, strlen(arr));

因为字符数组arr中没有 \0 ,所以在求字符串长度的时候,会一直往后找,产生的结构就是随机值

  • 因为 strlen 找不到 \0 就会一直往后计算字符长度只到找到 \0
  • 所以printf(“%d\n”, strlen(arr));
  • 是随机值

printf(“%d\n”, strlen(arr+0));

这个情况依旧和前面一样,arr + 0是首元素的地址,和第一个一样,也是随机值

  • 所以printf(“%d\n”, strlen(arr+0));
  • 是随机值

printf(“%d\n”, strlen(*arr));

这里就完全错误了,strlen需要的是地址。而你解引用给我传过来一个元素所以程序一定会崩溃。


printf(“%d\n”, strlen(arr[1]));

这里和前面一样的错误,我们需要的是地址。而你传的却是元素,这时程序就会崩溃!


printf(“%d\n”, strlen(&arr));

这里还是一样的传过去的是字符数组第一个元素的地址,但是没 \0 做为字符结束的标志所以还是随机值。


printf(“%d\n”, strlen(&arr+1));

这里还是一样的传过去的是字符数组第二个元素的地址,但是没 \0 做为字符结束的标志所以还是随机值。


printf(“%d\n”, strlen(&arr[0]+1));

这里还是一样的传过去的是字符数组第二个元素的地址,但是没 \0 做为字符结束的标志所以还是随机值。

📝全篇总结

✅ 归纳:

☁️ 好了以上就是关于数组类型笔试题要考察的点全部讲解了,不知道大家对数组和数组名是不是有了新的理解呢?

看到这里了还不给博主扣个:
⛳️ 点赞☀️收藏 ⭐️ 关注

💛 💙 💜 ❤️ 💚💓 💗 💕 💞 💘 💖

拜托拜托这个真的很重要!

你们的点赞就是博主更新最大的动力!

有问题可以评论或者私信呢秒回哦。

目录
相关文章
|
3月前
|
存储 C语言 C++
【c语言】运算符汇总(万字解析)
今天博主跟大家分享了c语言中各种操作符的功能、使用方法以及优先级和结合性,并且与大家深入探讨了表达式求值的两个重要规则--算数转换和整形提升。学习这些知识对我们的C语言和C++学习都有着极大的帮助。
184 2
|
2月前
|
存储 网络协议 编译器
【C语言】深入解析C语言结构体:定义、声明与高级应用实践
通过根据需求合理选择结构体定义和声明的放置位置,并灵活结合动态内存分配、内存优化和数据结构设计,可以显著提高代码的可维护性和运行效率。在实际开发中,建议遵循以下原则: - **模块化设计**:尽可能封装实现细节,减少模块间的耦合。 - **内存管理**:明确动态分配与释放的责任,防止资源泄漏。 - **优化顺序**:合理排列结构体成员以减少内存占用。
194 14
|
2月前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
77 8
|
2月前
|
存储 算法 C语言
【C语言】深入浅出:C语言链表的全面解析
链表是一种重要的基础数据结构,适用于频繁的插入和删除操作。通过本篇详细讲解了单链表、双向链表和循环链表的概念和实现,以及各类常用操作的示例代码。掌握链表的使用对于理解更复杂的数据结构和算法具有重要意义。
765 6
|
2月前
|
存储 网络协议 算法
【C语言】进制转换无难事:二进制、十进制、八进制与十六进制的全解析与实例
进制转换是计算机编程中常见的操作。在C语言中,了解如何在不同进制之间转换数据对于处理和显示数据非常重要。本文将详细介绍如何在二进制、十进制、八进制和十六进制之间进行转换。
93 5
|
2月前
|
C语言 开发者
【C语言】断言函数 -《深入解析C语言调试利器 !》
断言(assert)是一种调试工具,用于在程序运行时检查某些条件是否成立。如果条件不成立,断言会触发错误,并通常会终止程序的执行。断言有助于在开发和测试阶段捕捉逻辑错误。
60 5
|
2月前
|
安全 搜索推荐 Unix
【C语言】《回调函数》详细解析
回调函数是指一个通过函数指针调用的函数。它允许将一个函数作为参数传递给另一个函数,并在特定事件发生时执行。这种技术使得编程更加灵活,可以动态决定在何时调用哪个函数。
86 1
|
1月前
|
存储 算法 C语言
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
62 23
|
1月前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
66 15
|
1月前
|
C语言
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
60 24

热门文章

最新文章

推荐镜像

更多