联系方式
学习资讯
对C语言数组的总结
对C语言数组的总结
数组(Array)是一系列相同类型的数据的集合,可以是一维的、二维的、多维的;较常用的是一维数组和二维数组,多维数组较少用到。
对数组的总结
1) 数组的定义格式为:type arrayName[length]type 为数据类型,arrayName 为数组名,length 为数组长度。 需要注意的是:
- 数组长度 length 较好是常量表达式,例如 10、20*4 等,这样在所有编译器下都能运行通过;如果 length 中包含了变量,例如 n、4*m 等,在某些编译器下就会报错,我们已在《C语言变长数组:使用变量指明数组的长度》一节专门讨论了这点。
- 数组是一个整体,它的内存是连续的;也就是说,数组元素之间是相互挨着的,彼此之间没有一点点缝隙。
- 一般情况下,数组名会转换为数组的地址,需要使用地址的地方,直接使用数组名即可。
2) 访问数组元素的格式为:
arrayName[index]index 为数组下标。注意 index 的值*大于等于零,并且小于数组长度,否则会发生数组越界,出现意想不到的错误,我们已在《C语言数组的越界和溢出》一节重点讨论过。
3) 可以对数组中的单个元素赋值,也可以整体赋值,例如:
- // 对单个元素赋值
- int a[3];
- a[0] = 3;
- a[1] = 100;
- a[2] = 34;
- // 整体赋值(不指明数组长度)
- float b[] = { 23.3, 100.00, 10, 0.34 };
- // 整体赋值(指明数组长度)
- int m[10] = { 100, 30, 234 };
- // 字符数组赋值
- char str1[] = "http://c.biancheng.net";
- // 将数组所有元素都初始化为0
- int arr[10] = {0};
- char str2[20] = {0};
4) 字符串是本章的重点内容,大家要特别注意字符串结束标志'\0',各种字符串处理函数在定位字符串时都把'\0'作为结尾,没有'\0'就到达不了字符串的结尾。
关于查找和排序
学完了数组,有两项内容大家可以深入研究了,分别是查找(Search)和排序(Sort),它们在实际开发中都经常使用,比如:- 给你 10 个打乱顺序的整数,要能够按照从小到大或者从大到小的顺序输出;
- 给定一个字符串 str1,以及一个子串 str2,要能够判断 str2 是否在 str1 中。
本章我们讲解了较简单的查找和排序算法,分别是顺序查找(遍历数组查找某个元素)和冒泡排序,这些都是较基本的,有兴趣的读者也可以深入研究,下面我给列出了几篇文章:
- C语言排序算法以及代码
- C语言选择排序算法以及代码
- C语言插入排序算法及代码
- C语言归并排序(合并排序)算法以及代码
- C语言顺序查找算法以及代码
- C语言二分查找(折半查找)算法以及代码
更多培训课程,学习资讯,课程优惠等学校信息,请进入 无锡达内教育无锡C++培训无锡C语言培训 网站详细了解,免费咨询电话:400-998-6158