一、一维数组
1、小练手
int main()
{
int a[10];
int i;
int as=sizeof(a)/sizeof(a[0]);
a[0]=0;
a[1]=1;
for(i=2;i<10;i++)
{
a[i]=a[i-1]+a[i-2];
}
for(i=0;i<10;i++)
{
printf("data[%d]:%d\n",i,a[i]);
}
return 0;
2、冒泡排序
int main()
{
int arr[]={12,8,3,9};
int i;
int j;
int temp;
int len=sizeof(arr)/sizeof(arr[0]);
for(i=0;i<len-1;i++)
{
for(j=0;j<len-i-1;j++)
{
if(arr[j]>arr[j+1])//<降序,>升序
{
temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
for(i=0;i<len;i++)
{
printf("%d ",arr[i]);
}
return 0;
}
3、简单选择排序
int main()
{
int arr[]={12,8,3,9};
int i;
int j;
int temp;
int len=sizeof(arr)/sizeof(arr[0]);
for(i=0;i<len-1;i++)
{
for(j=i+1;j<len;j++)
{
if(arr[i]>arr[j])//<降序,>升序
{
temp=arr[i];
arr[i]=arr[j];
arr[j]=temp;
}
}
}
for(i=0;i<len;i++)
{
printf("%d ",arr[i]);
}
return 0;
}
二、二维数组
1、demo
int main()
{
int arr[2]={1,2};
int arry[2][3]={{2,3,4,},{7,8,9}};//可以不写行数,但一定要写列数
//int arry[2][3]={2,3,4,7,8,9};
int i,j;
for(i=0;i<2;i++)
{
for(j=0;j<3;j++)
{
//printf("%d,%d,%d \n",i,j,arry[i][j]);
printf("%d %p ",arry[i][j],&arry[i][j]);
}
putchar('\n');
}
return 0;
}
2、有一个3*4的矩阵,要求编程求出其中值最大的那个元素的值,以及其所在的行号和列号
int main()
{
int arr[3][4]={12,13,16,11,10,45,111,344,57,678,234,456};
int max;
int i,j;
int hang,lie;
max=arr[0][0];
for(i=0;i<3;i++)
{
for(j=0;j<4;j++)
{
printf("%d \t",arr[i][j]);
}
printf("\n");
}
for(i=0;i<3;i++)
{
for(j=0;j<4;j++)
{
if(max<arr[i][j])
{
max=arr[i][j];
hang=i+1;
lie=j+1;
}
}
}
printf("在第%d行第%d列最高为%d",hang,lie,max);
return 0;
}