重新学习C语言的第一天

一、一维数组的初始化
①动态赋值的方法:

#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");
	}
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章