一、一维数组的初始化
①动态赋值的方法:
#include<stdio.h>
int main()
{
int i,a[10],max;
printf("input 10 number\n");
//动态赋值,数组的初始化
for(i=0;i<=9;i++)
{
scanf("%d",&a[i]);
}
max=a[0];
for(i=1;i<=9;i++)
{
if(a[i]>max)
max=a[i];
}
printf("the max is:%d",max);
}
②利用数组来处理,求解Fibonacci数列。
(Fibonacci数列公式:已知:a1=a2=1 an=an-1 + an-2,即:1,1,2,3,5,8,13,……)
过程:先定义一个20个元素的数组,并将数组的第一,第二个元素都初始化为1,其他元素初始化为0,通过公式求出其他各个元素的值。
#include<stdio.h>
int main()
{
int i;
int a[20]={1,1};
for(i=2;i<=19;i++)
{
a[i]=a[i-1]+a[i-2];
}
for(i=0;i<20;i++)
{
if(0==i%5)
{
printf("\n");
}
printf("%12d",a[i]);
}
printf("\n");
}
③用冒泡对10个数排序(由小到大)。
冒泡法的思路是:将相邻两个数比较,将小的调到前头。
n个数要比较n - 1趟,第一躺比较n - 1次,第 j 趟需要比较n - j 次。
#include<stdio.h>
int main()
{
int i,j,t;
int a[10];
printf("input 10 numbers:\n");
for(i=0;i<10;i++)
{
scanf("%d",&a[i]);
}
printf("\n");
for(i=0;i<9;i++)
{
for(j=0;j<9-i;j++)
{
if(a[j]>a[j+1])
{
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
}
}
}
printf("this is new numbers:\n");
for(i=0;i<10;i++)
{
printf("%d",a[i]);
}
printf("\n");
}
二、二维数组的简单程序举例
①将一个二维数组行和列元素互换,存到另一个二维数组中。
#include<stdio.h>
int main()
{
int a[2][3]={{1,2,3},{4,5,6}};
int b[3][2];
int i,j;
printf("array a:\n");
for(i=0;i<2;i++)
{
for(j=0;j<3;j++)
{
printf("%5d",a[i][j]);
b[j][i]=a[i][j];
}
printf("\n");
}
printf("array b:\n");
for(i=0;i<3;i++)
{
for(j=0;j<2;j++)
{
printf("%5d",b[i][j]);
}
printf("\n");
}
}
②有一个3X4的矩阵,要求编程求出其中值最大的那个元素的值,以及其所在的行号和列号。
#include<stdio.h>
int main()
{
int i,j;
int row=0,colum=0;
int a[3][4]={{1,2,3,4},{9,5,6,7},{-6,7,8,2}};
int max=a[0][0];
for(i=0;i<3;i++)
{
for(j=0;j<4;j++)
{
if(max<a[i][j])
{
max=a[i][j];
colum=j+1;
row=i+1;
}
}
}
printf("max= %d ,row= %d ,colum= %d" ,max,row,colum);
printf("\n");
}
③从键盘上输入九个整数,(对照九宫格的形式,输入三行,每行输入三个数)保存在二位数组中,按数组原来位置输出第一行和第一列的所有元素。
#include<stdio.h>
int main()
{
int i,j;
int a[3][3];
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
printf("a[%d][[%d]=",i,j);
scanf("%d",&a[i][j]);
}
}
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
if(i==1||j==1)
{
printf("%-6d",a[i][j]);
}
else
{
printf("%-6c",' ');
}
}
printf("\n");
}
}