1.二维数组定义:
二维数组是一种特殊的一维数组,其元素本身又是一维数组。
定义形式:类型说明符 数组名[常量表达式1][常量表达式2]; 其中,常量表达式1 表示行数,
常量表达式2 表示列数。
2. 二维数组的声明
在C语言中,二维数组的声明方式如下:
例如,声明一个3行4列的整型二维数组:
int array[3][4];
3. 初始化二维数组
二维数组可以在声明时直接初始化。初始化时,可以按行来指定每个元素的值。
int array[3][4] = {{1, 2, 3, 4},{5, 6, 7, 8},{9, 10, 11, 12}};
int array[3][4] = {1, 2, 3, 4,5, 6, 7, 8,9, 10, 11, 12};
或者部分初始化,未指定的元素将自动初始化为0。
4. 访问二维数组的元素
访问二维数组的元素时,需要使用两个索引:行索引和列索引。
int secondRowThirdColumn = array[1][2]; // 访问第二行第三列的元素
注意,索引是从0开始的哦!
5. 二维数组的应用
1.打印二维数组;
//打印二维数组
#include<stdio.h>
#include<string.h>
#if 0
int main(void)
{
int a[3][4];
int i,j,k =1;
for(i = 0;i<3;++i)
{
for(j = 0;j<4;++j)
{
a[i][j] = k++;
}
}
for(i = 0;i<3;++i)
{
for(j = 0;j<4;++j)
{
printf("%-2d ",a[i][j]);
}
putchar(10);
}
return 0;
}
2.二维数组二分法
//er fen fa008
int main(void)
{
char s[][100] = {"Hello","World","China","America"};
int rows = sizeof(s)/sizeof(s[0]);
int i,j;
for( i = 0;i < rows - 1;++i)
{
for(j=i+1;j<rows;++j)
{
if(strcmp(s[i],s[j])>0)
{
char t[100];
strcpy(t,s[i]);
strcpy(s[i],s[j]);
strcpy(s[j],t);
}
}
}
char str[100] = "China";
int begin = 0;
int end = rows -1;
int mid;
while(begin <= end)
{
mid =(begin +end)/2;
if(strcmp(str,s[mid])>0)
{
begin = mid +1;
}
else if(strcmp(str,s[mid])<0)
{
end =mid - 1;
}
else
{
break;
}
}
if(begin <= end)
{
printf("found\n");
}
else
{
printf("no found\n");
}/*
for( i = 0;i<rows;++i)
{
puts(s[i]);
}*/
return 0;
}
3.魔方阵
//魔方阵
int main(void)
{
int a[3][3] = {0};
int i = 0,n;
int j = 1;
a[i][j] = 1;
int rows = sizeof(a)/sizeof(a[0]);
int cols = sizeof(a[0])/sizeof(a[0][0]);
for( n =2;n<10;++n)
{
int x = i;
int y = j;
++j;
if(j>2)
{
j = 0;
}
--i;
if(i<0)
{
i = 2;
}
if(a[i][j] !=0)
{
i = x;
y =j;
++i;
if(i>2)
{
i =0;
}
}
a[i][j] = n;
}
for(i = 0;i<rows;++i)
{
for(j = 0;j<cols;++j)
{
printf("%-2d ",a[i][j]);
}
putchar(10);
}
return 0;
}
6. 遍历二维数组
遍历二维数组时,通常需要使用两层循环,一层控制行,一层控制列。
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 4; j++)
{
printf("%d ", array[i][j]);
}
printf("\n"); // 每打印完一行后换行
}
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 4; j++) {
printf("%d ", array[i][j]);
}
printf("\n"); // 每打印完一行后换行
}
7. 注意事项
在使用二维数组时,要注意不要越界访问,即访问的行索引或列索引超出了数组的大小。
初始化二维数组时,可以省略行大小,但列大小必须指定。
8.函数概念
函数是C语言的基本构建块,用于分解复杂问题为可单独解决的小问题。模块化编程,便于协
作和维护。
包括返回类型、函数名、参数列表和函数体。
形式:返回类型 函数名(参数类型1 参数名1, ...) { // 函数体 return 返回值; }
先声明后调用。
调用时写出函数名和实参列表,如 c = max(a, b);
形式参数:函数定义时给出,仅在函数内部有效。
实际参数:调用函数时传递给形式参数的表达式或值。
通过 return 语句返回给调用者。
无返回值函数使用 void 类型,可省略 return 语句或使用 return; 结束函数。
嵌套调用:一个函数内部调用另一个函数。
递归调用:函数内部调用自身,需避免无限递归导致的栈溢出。
自定义函数:由程序员定义,实现特定功能。
库函数:由C语言标准库或第三方库提供,如 printf、scanf 等,需包含相应头文件。