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