本文主要是介绍6.11 c语言,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
八、数组
8.1 一维数组
数组是具有一定顺序关系的若干个变量的集合,组成数组的各个变量称为数组的元素
数组中各元素的数据类型要求相同,用数组名和下标确定,数组可以是一维的,也可以是多维的。
8.1.1 一维数组的定义
1、只有一个下标的数组,它在计算机的内存中是连续存储的
2、一般形式:<存储类型><数据类型> <数组 名>[<表达式>]
数组名表示内存首地址,是地址常量,sizeof(数组名)是数组占用的总内存空间
#include <stdio.h>
#include <stdlib.h>int main()
{int a[6],i;for(i=0;i<6;i++){printf("%p\n",a+i);}printf("%d",sizeof(a));return 0;
}
8.1.2 一维数组的引用
数组必须先定义,再引用
只能逐个引用数组元素,不能一次引用整个数组
数组元素表示形式:数组名[下标]
8.1.3 一维数组的初始化
1、初始化方式:定义数组的时候,为数组元素赋初值
int a[5] = {1,2,3,4,5};
2、数组不初始化,其元素值为随机数
对static数组元素不赋初值,系统会自动赋以0//static int a[5];
3、只给部分数组元素赋初值
#include <stdio.h>
#include <stdlib.h>int main()
{int a[] = {1,2,3,4,5,6},i,n;n =sizeof(a)/sizeof(int);for(i=0;i<n;i++){printf("a[%d] = %d\n",i,a[i]);}return 0;
}
//冒泡排序
#include <stdio.h>
#include <stdlib.h>int main()
{int a[] = {6,55,15,8,2};int i,j,t,n;n = sizeof(a)/sizeof(int);for(i=0;i<n;i++){printf("%d ",a[i]);}puts("");for(i=0;i<n-1;i++){for(j=0;j<n-1-i;j++)//第一轮5个数4次比较{if(a[j]>a[j+1]){t = a[j];a[j] = a[j+1];a[j+1] = t;}}}for(i=0;i<n;i++){printf("%d ",a[i]);}return 0;
}
8.2 二维数组
8.2.1 二维数组的定义
数据类型 数组名[ ][ ];
元素个数 = 行数*列数;
8.2.2 二维数组的存放顺序
原因:内存是一维的
二维数组:按行序优先
8.2.3 二维数组的引用
分行初始化
按元素排序顺序初始化
行号可以省略,列数不可以省略
#include <stdio.h>
#include <stdlib.h>int main()
{int a[][3] = {{1,2,3},{4,5,6}};int i,j;for(i=0;i<2;i++){for(j=0;j<3;j++){printf("%d ",a[i][j]);}printf("\n");}printf("a[0] = %p %d\na[1] = %p %d",a[0],sizeof(a[0]),a[1],sizeof(a[1]));return 0;
}
这篇关于6.11 c语言的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!