C语言数组笔试题解析

news/2024/6/19 4:54:05 标签: 1024程序员节, c语言

文章目录

    • C语言数组笔试题解析
      • 一维数组
      • 字符数组
      • 二维数组

C语言数组笔试题解析

数组名:

  1. sizeof(数组名):数组名表示整个数组,计算的是整个数组的大小
  2. &数组名:数组名表示的是整个数组,取出的是整个数组的地址

除此之外,所有的数组名都是数组首元素的地址


一维数组

int main()
{
	int a[] = { 1,2,3,4 };
	printf("%d\n", sizeof(a));//16  数组名a单独放在sizeof内部,数组名表示的是整个数组,计算的是整个数组的大小
	printf("%d\n", sizeof(a + 0));//4/8  a表示首元素的地址,a+0还是首元素的地址
	printf("%d\n", sizeof(*a));//4  a表示首元素的地址,*a就是首元素==》 a[0]
	//*a <==> *(a+0) <==> a[0]
	printf("%d\n", sizeof(a + 1));//4/8  a表示首元素的地址,a+1是第二个元素的地址
	printf("%d\n", sizeof(a[1]));//4  就是第二个元素
	printf("%d\n", sizeof(&a));//4/8  &a - 数组的地址 
	printf("%d\n", sizeof(*&a));//16  &a是数组的地址,对数组的地址解引用拿到的是数组
	printf("%d\n", sizeof(&a + 1));//4/8  &a是数组的地址,&a+1是数组地址+1,跳过整个数组,还是地址
	printf("%d\n", sizeof(&a[0]));//4/8
	printf("%d\n", sizeof(&a[0] + 1));//4/8

	return 0;
}

字符数组

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

	return 0;
}

strlen - 库函数

求字符串长度

sizeof - 操作符 - 单位是字节

求变量所占空间的大小

求类型创建的变量所占空间的大小

int main()
{
	char arr[] = { 'a','b','c','d','e','f' };
	printf("%d\n", strlen(arr));//随机值
	printf("%d\n", strlen(arr + 0));//随机值
	printf("%d\n", strlen(*arr));//*arr - 'a' - 97
	//strlen以为传进来的'a'的ascii码值就是地址
	printf("%d\n", strlen(arr[1]));//'b' - 98 -err
	printf("%d\n", strlen(&arr));//随机值
	printf("%d\n", strlen(&arr + 1));//随机值
	printf("%d\n", strlen(&arr[0] + 1));//随机值

	return 0;
}
int main()
{
	char arr[] = "abcdef";//{a b c d e f \0}//7
	printf("%d\n", sizeof(arr));//7字节
	printf("%d\n", sizeof(arr + 0));//4/8  首元素地址
	printf("%d\n", sizeof(*arr));//1  arr是首元素地址,*arr就是首元素
	printf("%d\n", sizeof(arr[1]));//1  第二个元素
	printf("%d\n", sizeof(&arr));//4/8  数组的地址,数组的地址也是地址
	printf("%d\n", sizeof(&arr + 1));//4/8  &a是数组的地址,&a+1是数组地址+1,跳过整个数组,还是地址
	printf("%d\n", sizeof(&arr[0] + 1));//4/8  第二个元素的地址

	return 0;
}
int main()
{
	char arr[] = "abcdef";//{a b c d e f \0}//7
	printf("%d\n", strlen(arr));//6
	printf("%d\n", strlen(arr + 0));//6
	printf("%d\n", strlen(*arr));//err
	printf("%d\n", strlen(arr[1]));//err
	printf("%d\n", strlen(&arr));//6
	printf("%d\n", strlen(&arr + 1));//随机值
	printf("%d\n", strlen(&arr[0] + 1));//5

	return 0;
}
int main()
{
	const char* p = "abcdef";
	printf("%d\n", sizeof(p));//4/8  p是一个指针变量
	printf("%d\n", sizeof(p + 1));//4/8  p+1是字符b的地址
	printf("%d\n", sizeof(*p));//1  
	printf("%d\n", sizeof(p[0]));//1  p[0]-->*(p+0)
	printf("%d\n", sizeof(&p));//4/8
	printf("%d\n", sizeof(&p + 1));//4/8
	printf("%d\n", sizeof(&p[0] + 1));//4/8

	return 0;
}
int main()
{
	const char* p = "abcdef";
	printf("%d\n", strlen(p));//6
	printf("%d\n", strlen(p + 1));//5
	printf("%d\n", strlen(*p));//err
	printf("%d\n", strlen(p[0]));//err  p[0]-->*(p+0)
	printf("%d\n", strlen(&p));//随机值
	printf("%d\n", strlen(&p + 1));//随机值
	printf("%d\n", strlen(&p[0] + 1));//5

	return 0;
}

二维数组

int main()
{
	int a[3][4] = { 0 };
	printf("%d\n", sizeof(a));//48  
	printf("%d\n", sizeof(a[0][0]));//4
	printf("%d\n", sizeof(a[0]));//16  a[0]是第一行的数组名,数组名单独放在sizeof内部
	printf("%d\n", sizeof(a[0] + 1));//4/8
	//a[0]是第一行的数组的数组名,并没有单独放在sizeof内部,也没有&,所以a[0]表示首元素的地址,就是这一行这个数组第一个元素的地址
	//所以a[0] + 1就是这一行,第二个元素的地址
	printf("%d\n", sizeof(*(a[0] + 1)));//4  *(a[0] + 1)就是第一行第二个元素
	printf("%d\n", sizeof(a + 1));//4/8  数组名a并没有单独放在sizeof内部,也没有&,所以a表示首元素(第一行)的地址
	//所以a+1,就是第二行的地址
	printf("%d\n", sizeof(*(a + 1)));//16  *(a+1)就是第二行
	printf("%d\n", sizeof(&a[0] + 1));//4/8  第二行地址
	printf("%d\n", sizeof(*(&a[0] + 1)));//16  第二行 - a[1]
	printf("%d\n", sizeof(*a));//16
	//a表示首元素(第一行)的地址
	//*a - 第一行 - 第一行的数组名
	//*a -> *(a+0) -> a[0]
	printf("%d\n", sizeof(a[3]));//16

	return 0;
}


http://www.niftyadmin.cn/n/1697752.html

相关文章

Python学习札记(二十六) 函数式编程7 修饰器

修饰器 NOTE 1.函数对象有一个__name__属性&#xff0c;可以拿到函数的名字&#xff1a; #!/usr/bin/env python3def now():print(2017/2/19)def main():f nowf()print(now.__name__)print(f.__name__)if __name__ __main__:main() sh-3.2# ./decorator1.py 2017/2/19 now n…

Java——数组的定义和使用

文章目录Java中数组的定义和使用1.数组的基本用法1.1什么是数组1.2创建数组1.3数组的使用2.数组作为方法的参数2.1基本用法2.2理解引用类型&#xff08;重点/难点&#xff09;2.3认识 null3.数组作为方法的返回值4.数组练习4.1数组转字符串4.2数组拷贝4.3找数组中的最大元素4.4…

Java——类和对象超详细总结

文章目录类和对象1.类与对象的初步认识2.类和类的实例化3.类的成员3.1字段/属性/成员变量3.2方法3.3 static关键字4.封装4.1 private实现封装4.2 getter和setter方法5.构造方法5.1基本语法5.2 this关键字6.认识代码块6.1什么是代码块6.2普通代码块6.3构造代码块6.4静态代码块类…

使用 docker 安装 OpenVAS 漏洞扫描软件

https://blog.csdn.net/freewebsys/article/details/78804624转载于:https://www.cnblogs.com/diyunpeng/p/9155637.html

Excel 学习笔记——排序,筛选,查找,定位,分类汇总和数据有效性及 细节操作技巧...

Excel 学习笔记 课程内容&#xff1a;查找、替换、定位 想要实现的目标内容&#xff1a; 1. 替换指定内容&#xff0c;例&#xff1a;苏州 <- 苏州市 红色背景色<- 黄色背景色 将“张某某”替换为“经理的亲戚”2. 定位特定位置的单元格&#xff0c;类似筛选…

LeetCode(114): 二叉树展开为链表

Medium&#xff01; 题目描述&#xff1a; 给定一个二叉树&#xff0c;原地将它展开为链表。 例如&#xff0c;给定二叉树 1/ \2 5/ \ \ 3 4 6 将其展开为&#xff1a; 1\2\3\4\5\6 解题思路&#xff1a; 这道题要求把二叉树展开成链表&#xff0c;根据展开后形成的链表…

Python 字符串方法

2019独角兽企业重金招聘Python工程师标准>>> 1、upper()和lower() 字符串大小写转换 2、isX 方法&#xff1a;判断 isalpha&#xff08;&#xff09;全字母组成&#xff0c;非空 isalnum() 全字母数字组成&#xff0c;非空 isupper&#xff08;&#xff09…

[行列式与矩阵树定理]【学习笔记】

为什么查基尔霍夫只能查到物理学家&#xff1f; 参考资料&#xff1a; 1.生成树的计数及其应用 2.http://blog.csdn.net/werkeytom_ftd/article/details/54914530 行列式 排列 Permutation 对换&#xff1a;相邻两项交换对换会使逆序对的个数改变1$\delta(i_1i_2...i_n)(-1)^{t…