?1.数组的概念
数组(Array)是有序的元素序列。 若将有限个类型相同的变量的集合命名,那么这个名称为数组名。组成数组的各个变量称为数组的分量,也称为数组的元素,有时也称为下标变量。用于区分数组的各个元素的数字编号称为下标。数组是在程序设计中,为了处理方便, 把具有相同类型的若干元素按有序的形式组织起来的一种形式。 这些有序排列的同类数据元素的集合称为数组。(出自360百科)
2.一维数组的创建和初始化?
#include<stdio.h>
int main()
{
int arr1[]={1,2,3,4};
char arr2[]="hello";
float arr3[];
double arr4[];
return 0;
}
数组的基本格式为:
数组类型——数组名——数组中元素的个数
数组的初始化:
往数组里存放元素即为数组的初始化,注意数组中元素个数不能超过[ ]中所填数字。
?注:数组创建时,[ ]中只能放常量,不能放变量。
?
sizeof和strlen的区别
sizeof | 计算数组所占空间的大小 |
---|
strlen | 计算 \0 之前的字符串长度 |
?
?
?
?
?
#include<stdio.h>
int main ()
{
char arr[]="abcdef";
printf("%d\n",sizeof(arr));//打印的值为7
printf("%d\n",strlen(arr));//打印的值为6
return 0;
}
?
3.一维数组的使用
对于数组的使用要用一个操作符[ ],下标引用操作符。它其实就是数组访问的操作符。?
?
#include<stdio.h。
int main()
{
int arr[]={1,2,3,4,5,6,7,8,9};
printf("%d\n",arr[3]);//打印值为4
printf("%d\n",arr[6]);//打印值为7
return 0;
}
?注:数组的下标是从0开始的,数组的最大下标比元素个数少1
?
?<计算元素个数即数组大小>
#include<stdio.h>
int main()
{
int arr[]={1,2,3,4,5,6}
int sz=0;
sz=sizeof(arr)/sizeof(arr[0]);
printf("%d\n",sz);//打印结果为6
return 0;
}
?4.一维数组在内存中的存储
一维数组在内存中是连续存放的
?
#include<stdio.h>
int main()
{
int arr[]={1,2,3,4,5,6,7,8,9,10};
int sz=sizeof(arr)/sizeof(arr[0]);
int i=0;
for(i=0;i<sz;i++)
{
printf("&arr[%d]=%p\n",i,&arr[i]);//地址相差4个字节,是连续的
}
return 0;
}
5.二维数组的创建和初始化
二维数组有行有列,需要两个[ ],并且行可以省略而列不能省略。
#include<stdio.h>
int main()
{
int arr[3][4];//表示3行4列的二维数组
char arr[4][5];
int arr[3][4]={1,2,3,4,5};//表示先放满第一行,再放第二行
int arr[3][4]={{1,2,3},{4,5}};//表示{1,2,3}放第一行,{4,5}放第二行
return 0;
}
?6.二维数组的使用
通过二维数组中的行和列来访问数组中的元素。
?
#include<stdio.h>
int main()
{
int arr[3][4] = { { 1, 2, 3 }, { 4, 5 } };
int i = 0;
for (i = 0; i < 3; i++)
{
int j = 0;
for (j = 0; j < 4; j++)
{
printf("%d", arr[i][j]);
}
printf("\n");
}
return 0;
}
<打印结果>
?
7.二维数组在内存中的存储?
?二维数组在内存中也是连续存放的
?
#include<stdio.h>
int main()
{
int arr[3][4] = { { 1, 2, 3 }, { 4, 5 } };
int i = 0;
for (i = 0; i < 3; i++)
{
int j = 0;
for (j = 0; j < 4; j++)
{
printf("&arr[%d][%d]= %p\n",i,j, &arr[i][j]);
}
}
return 0;
}
8.数组作为函数参数:冒泡排序
void bubble_sort(int arr[], int sz)//括号里放的是传过来的参数,可以有多个
{ //确定冒泡排序的趟数
int i = 0;
for (i = 0; i < sz - 1; i++)
{
int flag = 1; //flag的设置可以使程序更高效
//每一趟冒泡排序需要排的个数
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]);
bubble_sort(arr, sz);
for (i = 0; i < sz ; i++)
{
printf("%d", arr[i]);
}
return 0;
}
?9.数组名
数组名就是首元素地址,但有两个例外:
1.sizeof(数组名),数组名表示整个数组。
2.&数组名,数组名表示整个数组,取出的是整个数组的地址。?
#include<stdio.h>
int main()
{
int arr[] = { 1, 2, 3, 4, 5, 6, 7 };
printf("%p\n", arr);
printf("%p\n", arr + 1);
printf("%p\n", &arr[0]);
printf("%p\n", &arr[0] + 1);
printf("%p\n", &arr);
printf("%p\n", &arr + 1);//相差28
return 0;
}
?以上是数组的全部内容,打字不容易,请大家多多关注,点个赞吧。
?
|