C语言数组和指针笔试题(一)(一定要看)

news2025/1/19 17:00:37

目录

  • 一维数组
    • 例题1
    • 例题2
    • 例题3
    • 例题4
    • 例题5
    • 例题6
    • 例题7
    • 例题8
    • 例题9
    • 例题10
    • 例题输出结果
  • 字符数组一
    • 例题1
    • 例题2
    • 例题3
    • 例题4
    • 例题5
    • 例题6
    • 例题7

一维数组

int a[] = {1,2,3,4};
1:printf("%d\n",sizeof(a));
2:printf("%d\n",sizeof(a+0));
3:printf("%d\n",sizeof(*a));
4:printf("%d\n",sizeof(a+1));
5:printf("%d\n",sizeof(a[1]));
6:printf("%d\n",sizeof(&a));
7:printf("%d\n",sizeof(*&a));
8:printf("%d\n",sizeof(&a+1));
9:printf("%d\n",sizeof(&a[0]));
10:printf("%d\n",sizeof(&a[0]+1));

例题1

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

这里的a表示整个数组,计算的是整个数组的大小,因此这里的结果为
4(数组元素) * 4(int类型所占大小)=16

例题2

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

注意这里a+0的a并不是整个数组,而是表示的首元素的地址
因为只有数组名单独在sizeof()括号里时,才表示整个数组,当数组名不是单独在sizeof()括号里时就仅表示数组首元素地址,虽然二者地址是一样的,但是本质是有区别的,因此a+0实际为&a[0],&a[0]的大小为4或者8个字节
为什么这里a+0!=a[0]呢?,因为a+0本质还是一个地址,而a[0]就是数组的一个元素,并不是地址,因此只有*(a+0)才等于a[0]

例题3

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

*a是数组的首元素,即 * a=a[0],sizeof(a[0])=4(整形类型的大小)

例题4

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

这道题其实和例题2基本上是一样的,a+1表示的是数组首元素的地址往后移一位,即a+1=a[1],因此为sizeof(a+1)的结果为4或者8个字节
这里其实可以直接得出答案,因为我们知道这里的a是首元素地址,因此既然a+1还是地址,那么地址的大小就是4或者8个字节

例题5

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

计算的是第二个元素的大小为4个字节(int类型的大小)

例题6

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

&a在之前我的一篇博客中有提到,能取整个数组地址的方式只有两种,一种是sizeof(数组名),另一种则是&(数组名)
因此**&a是整个数组的地址,既然是地址那么结果还是4或者8个字节**

例题7

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

这里的**&a是整个数组的地址**,* 对整个数组解引用,因此sizeof( *&a)就是计算的整个数组的大小,所以结果就是16

例题8

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

&a是表示整个数组的地址,这里的+1不是让数组的首元素地址移动到下一位,而是直接跳过整个数组
在这里插入图片描述
既然是数组的地址,那么依然是4或者8个字节

例题9

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

&a[0]是取的数组首元素地址,所以大小为4或者8个字节

例题10

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

上题已经说了既然是首元素地址,因此这里的+1就是跳到下一个元素的地址,&a[0]+1=&a[1],大小是4或者8个字节

例题输出结果

在这里插入图片描述

字符数组一

char arr[] = "abcdef";
1:printf("%d\n", sizeof(arr));
2:printf("%d\n", sizeof(arr+0));
3:printf("%d\n", sizeof(*arr));
4:printf("%d\n", sizeof(arr[1]));
5:printf("%d\n", sizeof(&arr));
6:printf("%d\n", sizeof(&arr+1));
7:printf("%d\n", sizeof(&arr[0]+1));

例题1

char arr[] = "abcdef";
1:printf("%d\n", sizeof(arr));

由于sizeof是只管求数组里的内存大小,而对于字符串是由字符’a’ ‘b’ ‘c’ ’ d’ ‘e’ ‘f’ '\0’组成,而一个字符的大小为一个字节,因此最后的输出结果为
7(字符串中的字符个数)*1(一个字符的内存大小)=7

例题2

char arr[] = "abcdef";
1:printf("%d\n", sizeof(arr+0));

arr+0在之前说过,这里的arr不是整个数组的地址,是首元素的地址,因此arr+0=arr[0],既然是地址那么结果就是4或者8

例题3

char arr[] = "abcdef";
1:printf("%d\n", sizeof(*arr));

arr为数组首元素地址,对arr解引用就是数组的第一个字符a,因为是char类型,所以结果就是1

例题4

char arr[] = "abcdef";
1:printf("%d\n", sizeof(arr[1]));

这里求的是第二个字符b,所以结果是1

例题5

char arr[] = "abcdef";
1:printf("%d\n", sizeof(&arr));

&arr是整个数组的地址,所以既然是地址那么结果就是4或者8

例题6

char arr[] = "abcdef";
1:printf("%d\n", sizeof(&arr+1));

&arr+1是跳过整个数组,但是仍然是地址,所以还是4或者8

例题7

char arr[] = "abcdef";
1:printf("%d\n", sizeof(arr[0]+1));

arr[0]+1跳过一个元素,所以就是arr[1],但是还是地址,所以仍然是4或者8

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

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

相关文章

TypeScript高级类型

🎬 岸边的风:个人主页 🔥 个人专栏 :《 VUE 》 《 javaScript 》 ⛺️ 生活的理想,就是为了理想的生活 ! 目录 映射类型(Mapped Types) 1. Readonly 2. Partial 3. Pick 4. Record 条件类型&#xf…

【javaSE】 反射与反射的使用

文章目录 🌲反射的定义🎍反射的用途🌴反射基本信息🍀反射相关的类🚩Class类(反射机制的起源 )🎈Class类中的相关方法 🚩反射示例🎈获得Class对象的三种方式🎈反射的使用 …

导数应用:曲线的凹凸性、渐进线、弧微分与曲率

目录 曲线的凹凸性 函数的拐点 曲线的渐近线 函数的弧微分与曲率 曲线的凹凸性 曲线的凹凸性是描述曲线在某一点处的曲率属性的几何性质。 具体来说,对于平面上的曲线,其在某一点的切线的斜率是不断变化的。当切线的斜率在某区间内恒为正值时&#…

基于HTML、CSS和JavaScript制作一个中秋节倒计时网页

💂 个人网站:【工具大全】【游戏大全】【神级源码资源网】🤟 前端学习课程:👉【28个案例趣学前端】【400个JS面试题】💅 寻找学习交流、摸鱼划水的小伙伴,请点击【摸鱼学习交流群】 这个项目使用HTML、CSS和…

第一百四十天学习记录:工作相关:Qt5.14.2的安装

最近一段时间被新项目搞得心力憔悴。 加上需要调用一个同事的OpenCV库一直报错,后面发现是Qt版本不兼容的问题。 在尝试了在线安装Qt无果后,重新安装Qt,顺便回顾一下Qt的安装过程。 毕竟上一次安装Qt还是在2019年……之后的这4年工作电脑和家…

TypeScript类型推断

🎬 岸边的风:个人主页 🔥 个人专栏 :《 VUE 》 《 javaScript 》 ⛺️ 生活的理想,就是为了理想的生活 ! 目录 类型推断 1. 基础类型推断 #2. 最佳公共类型推断 3. 上下文类型推断 4. 类型断言 #5. 类型推断和泛型 总结 类…

【javaSE】 Lambda表达式与Lambda表达式的使用

文章目录 🌳Lambda表达式的背景🚩Lambda表达式的语法🚩函数式接口 🎋Lambda表达式的基本使用🎄语法精简 🌲变量捕获🚩匿名内部类🚩匿名内部类的变量捕获🚩Lambda的变量捕…

【力扣-二叉树-01】在二叉树中分配硬币-力扣 979 题

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学…

多层全连接网络:实现手写数字识别50轮准确率92.1%

多层全连接网络:实现手写数字识别50轮准确率92.1% 1 导入必备库2 torchvision内置了常用数据集和最常见的模型3 数据批量加载4 绘制样例5 创建模型7 设置是否使用GPU8 设置损失函数和优化器9 定义训练函数10 定义测试函数11 开始训练12 绘制损失曲线并保存13 绘制准…

C++ std::future

std::future是用来接收一个线程的执行结果的,并且是一次性的。 共享状态shared state future可以关联一个共享状态,共享状态是用来储存要执行结果的。这个结果是async、promise、packaged_task设置的,且这个结果只能设置一次。 创建future …

【rtp-benchmarks】读取本地文件基于uvgRtp实现多线程发送

input 文件做内存映射 : get_mem D:\XTRANS\soup\uvg-rtp-dev\rtp-benchmarks\util\util.cc 文件中读取chunksize 到 vector 里作为chunks 创建多个线程进行发送 std::vector<std::thread*> threads;

C++数据结构X篇_12_树的基本概念和存储

学习二叉树之前先学习树的概念。 文章目录 1. 树的基本概念1.1 树的定义1.2 树的特点1.3 若干术语 2. 树的表示法2.1 图形表示法2.2 广义表表示法 3. 树的存储3.1 双亲表示法&#xff1a;保存父节点关系3.2 孩子表示法3.3 左孩子右兄弟表示法 1. 树的基本概念 之前所学均为线性…

22 相交链表

相交链表 题解1 快慢双指针改进 (acb bca)题解2 哈希表(偷懒) 给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点&#xff0c;返回 null 。 题目数据 保证 整个链式结构中不存在环。 注意&#xff…

Golang gorm manytomany 多对多 更新、删除、替换

Delete 移除 只删除中间表的数据 删除原有的 var a Article1db.Preload("Tag1s").Take(&a, 1)fmt.Printf("%v", a) {1 k8s [{1 cloud []} {2 linux []}]}mysql> select * from article1; ------------ | id | title | ------------ | 1 | k8s …

导数公式及求导法则

目录 基本初等函数的导数公式 求导法则 有理运算法则 复合函数求导法 隐函数求导法 反函数求导法 参数方程求导法 对数求导法 基本初等函数的导数公式 基本初等函数的导数公式包括&#xff1a; C0(x^n)nx^(n-1)(a^x)a^x*lna(e^x)e^x(loga(x))1/(xlna)(lnx)1/x(sinx)cos…

十大排序算法及Java中的排序算法

文章目录 一、简介二、时间复杂度三、非线性时间比较类排序冒泡排序&#xff08;Bubble Sort&#xff09;排序过程代码实现步骤拆解演示复杂度 选择排序&#xff08;Selection Sort&#xff09;排序过程代码实现步骤拆解演示复杂度 插入排序&#xff08;Insertion Sort&#xf…

用冒泡排序完成库函数qsort的作用

Hello&#xff0c;今天分享的是我们用冒泡函数实现qsort&#xff0c;也就是快排&#xff0c;之前我们也讲过库函数qsort的使用方法&#xff0c;今天我们尝试用冒泡函数实现一下&#xff0c;当然我们也见过qsort&#xff0c;后面也会继续完善的。这几天我是破防大学生&#xff0…

使用python制作一个简单的任务管理器

本篇文章教大家 使用 Python 创建一个简单的任务管理器应用程序。这个项目将帮助你练习 Python 编程的许多方面&#xff0c;包括文件操作、用户输入处理和基本的命令行界面设计。在这篇文章中&#xff0c;我将指导你创建一个基本的命令行任务管理器。 目录 任务管理器的用途任务…

NLP机器翻译全景:从基本原理到技术实战全解析

目录 一、机器翻译简介1. 什么是机器翻译 (MT)?2. 源语言和目标语言3. 翻译模型4. 上下文的重要性 二、基于规则的机器翻译 (RBMT)1. 规则的制定2. 词典和词汇选择3. 限制与挑战4. PyTorch实现 三、基于统计的机器翻译 (SMT)1. 数据驱动2. 短语对齐3. 评分和选择4. PyTorch实现…

App Inventor 2 实现Ascii码转换(Ascii编码与解码)

之前有同学问&#xff0c;App Inventor 2 字符及Ascii码如何进行转换&#xff0c;经过调查&#xff0c;其原生的组件和内置块无法完成这个功能&#xff0c;网上也有利用Web客户端组件执行js代码来进行转换&#xff0c;不过逻辑稍复杂效率还不高。这里介绍一个拓展可以非常方便的…