程序员的知识教程库

网站首页 > 教程分享 正文

【C语言】数组(c语言数组知识点总结)

henian88 2024-10-25 11:54:09 教程分享 2 ℃ 0 评论

1、什么是数组

典型的复合类型:同一类型变量的连续内存组成的数据类型。数组定义时(没初始化),必须指定数组的大小(或长度),数组大小必须是整形常量表达式,不能是变量或变量表达式。

下面定义数组错误的写法

1. int n = 3;

2. int b[n];错误

3. int c[10.3];错误

(important)

#define m 4

Int d[m]; 正确 宏定义可以

Int e[] = {1,2,3,4} 这也是可以的,编译器会自动识别数组e的大小为4

一维数组在内存当中是连续的一段内存单元,首地址为数组名字 e == &e[0];

例如 int a[3] = {1,3,4};

数组下标从0开始,所以数组不能越界,只能取到a[2]的值

不能取到a[3]的值a + i 等价于 &a[i] *(a+i) = *&a[i] = a[i]

#include <stdio.h>
#define n 3
int main () {
	int a[n] = {1,3,4};
	int i=0;
	//a 首地址 a+1,a+2, 
	for(;i<n;i++)
	{
		printf("a[%d]的地址是:%p,&a[%d] = %p\n",i,a+i,i,&a[i]);	
	}
	return 0;
}

求数组的长度

int len = sizeof(a) / sizeof(int);

int a[5] = {1,2,3};

数组大小为5,但是初始化只给了前三个值,后面的两个值默认被赋值为0

冒泡排序举例如下:

void bubbleSort(int a[],int length)
{
	int i,j,temp = 0;
	for(i=1;i<length;i++)
	{
		for(j=0;j<length-i;j++)
		{
			if(a[j]>a[j+1])
			{
				temp = a[j];
				a[j] = a[j+1];
				a[j+1] = temp;		
			}
		}
	}
}

选择排序如下:

void selectSort(int a[],int length)
{
	int i,j,k,t;
	for(i=0;i<length;i++)
 	{
		k = i;
        for(j = i+1;j<length;j++)
		{
			if(a[k]>a[j]) k = j;	
		}
		if(i!=k)
		{
			t = a[i];
			a[i] = a[k];
			a[k] = t;
		}
	}
}

2、二维数组

int a[2][3] = {1,2,3,4,5,6}; 两行三列

可以看出 二维数组在内存当中是以行存储的顺序存储方式

二维数组是特殊的一维数组

初始化

Int a[][3] = {1,2,3,4};

代表列的数must不能省略

1

2

3

4

0

0

3、字符串与数组

‘a’ ‘\101’ = ‘A’(转义字符考察的比较多)

字符串是一种以’\0’结尾的字符数组

字符数组和字符串。

三个等价

char str[] = “china”;

char str[] = {‘c’,’h’,’I’,’n’,’a’,’\0’};

char str[] = {“china”}

字符串不能这样赋值

char str[] = {‘c’,’h’,’I’,’n’,’a’}; //not 字符串

这是一个数组,但不是字符串,没有’\0’结尾

char str[10];

str = “china”;

这样也不行,数组名字是数组的首地址,不能赋值

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表