二维数组的创建和初始化
二维数组的创建
//数组创建
//数组创建
int arr[3][4];//3行4列
char arr[3][4];//3行4列
double arr[3][4];//3行4列
二维数组的初始化
//数组初始化
int arr[3][4] = {1,2,3,4};
int arr[3][4] = {{1,2},{4,5}};
int arr[][4] = {{2,3},{4,5}};
二维数组的使用
二维数组的使用也是通过下标的方式:
#include <stdio.h>
void bubble_sort(int arr[],int sz)
{
int flag = 1;//假设这一趟要排序的数据已经有序
//确定冒泡排序的趟数
int i = 0;
for (i = 0; i < sz - 1; i++)
{
//每一趟冒泡排序
int j = 0;
for (j = 0; j < sz - 1 - i; j++)
{
if (arr[j] > arr[j + 1])
{
int tmp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = tmp;
flag = 0;//本趟排序的数据未完全有序
}
}
if(flag == 1)
{
break;
}
}
}
int main()
{
int arr[] = {9,8,7,6,5,4,3,2,1,0};
int i = 0;
int sz = sizeof(arr) / sizeof(arr[0]);
//对arr排序,排成升序
//arr是数组,我们对数组arr进行传参,实际上传递过去的是数组arr首元素的地址 &arr[0]
bubble_sort(arr,sz);//冒泡排序函数
for (i = 0; i < sz; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
注:break语句只用于for和switch,在if语句中不能使用,因为if不是循环语句,所以不能用break来结束。
int main()
{
int arr[] = {1,2,3,4,5,6,7};
printf("%p\n", arr);
printf("%p\n", &arr[0]);
printf("%d\n", *arr);
//输出结果
return 0;
}
结论:运算结果是一样的,说明数组名就是我们的数组首地址。(有两个例外)
int main()
{
int arr[] = {1,2,3,4,5,6,7};
printf("%p\n", arr);
printf("%p\n", &arr[0]);
printf("%p\n", &arr);//取出的是数组的地址
//int sz = sizeof(arr)/sizeof(arr[0]);
//1、sizeof(数组名) - 数组名表示整个数组,sizeof(数组名)计算的是整个数组的大小,单位是字节
//2、&数组名,数组名代表整个数组,&数组名,去除的是整个数组的地址
return 0;
}