一、一維數組的初始化
①動態賦值的方法:
#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");
}
}