1. 程式人生 > 實用技巧 >實驗五 陣列和函式

實驗五 陣列和函式

實驗任務1

#include<stdio.h>
const int N=3;

int main(){
	int a[N]={1,2,3};
	int i;
	
	printf("通過陣列名及下標直接訪問陣列元素:\n");
	for(i=0;i<N;i++)
		printf("%d:%d\n",&a[i],a[i]);
		
	printf("通過地址間接訪問陣列元素:\n");
	for(i=0;i<N;i++)
		printf("%d:5d\n",a+i,*(a+i));
			
	return 0;
}

問:1.陣列元素在記憶體中是否是連續存放的?    答:是

   2.對於陣列元素及其地址的訪問,以下訪問方式是否是等價的?    答:是

實驗任務2

#include<stdio.h>
const int LINE=2;
const int COL=3;

int main(){
	int a[LINE][COL]={1,2,3,4,5,6};
	int i,j;
	
	printf("通過陣列明基下表直接訪問數:\n");
	for(i=0;i<LINE;i++)
		for(j=0;j<COL;j++)
			printf("%d:%d\n",&a[i][j]);
			
	printf("通過地址間接訪問陣列元素:\n");
	for(i=0;i<LINE;i++)
		for(j=0;j<COL;j++)
			printf("%d:%d\n",a[i]+j,*(a[i]+j));
			
	printf("二維地址中a+i表示的地址:\n");
	for(i=0;i<LINE;i++)
		printf("a+%d:%d\n",i,a+i);
		
	return 0;
}

問:1.C語言中,二維陣列在記憶體中是否是按行存放的?    答:是

   2.對於二維陣列元素及其地址的訪問,以下方式是否是等價的?    答:是

   3.對於二維陣列a[2][3],以下方式是否是等價的?    答:是

實驗任務3

// 使用指標變數間接訪問一維陣列 
#include <stdio.h> 
#include <stdlib.h> 

const int N=3;

int main() {
	int a[N];
	int *p,i;
	
	// 通過指標變數p,完成陣列元素輸入
	for(p=a; p<a+N; p++)
		scanf("%d", p);
	
	// 過指標變數p,完成陣列元素輸出
	for(p=a; p<a+N; p++)
		printf("%d ", *p);
	printf("\n");
	
	p = a;
	//通過指標變數p,完成陣列元素輸入
	for(i=0; i<N; i++)
		scanf("%d", p+i); 
		
	// 通過指標變數p,完成陣列元素輸出
	for(i=0; i<N; i++)
		printf("%d ", *(p+i));
	printf("\n"); 

	return 0;
}  

問:1.程式中,指標變數p在使用時是否指向確定的地址?    答:不,根據輸入值的不同,其指向也不同。

   2.程式原始碼中,line12-line13執行完後,指標變數p指向哪裡?line16-line17執行完後,指標變數p指向哪裡?    答:指向a[N]

   3.程式原始碼中,line22-line27執行完後,指標變數p指向哪裡?line26-27執行完後,指標變數p指向哪裡?    答:指向a所在的地址

//使用指標變數訪問二維陣列 
#include<stdio.h>

int main(){
	int a[2][3]={1,2,3,4,5,6};
	int i,j;
	int *p;
	int (*q)[3];
	
	for(p=a[0];p<a[0]+6;p++)
		printf("%d",*p);
	printf("\n");
	
	for(q=a;q<a+2;q++)
		for(j=0;j<3;j++)
			printf("%d",*(*q+j));
	printf("\n");
	
	return 0;
}
 

問:1.程式原始碼中,line11改成如下形式是否可以?    答:可以

  2.程式原始碼中,line18中,*q+j和*(*q+j)分別表示什麼?    答:前者表示a[0]+j的值;後者表示a[0]+j的地址

  3.???

  4.A、F

實驗任務5

1、

// 練習:使用二分查詢,在一組有序元素中查詢資料項
//  形參是陣列,實參是陣列名 
#include  <stdio.h>

const int N=5;

int binarySearch(int x[], int n, int item); // 函式宣告 

int main() {
	int a[N]={2,7,19,45,66};
	int i,index, key;
	
	printf("陣列a中的資料:\n");
	for(i=0;i<N;i++)
	   printf("%d ",a[i]);
	printf("\n");
	
	printf("輸入待查詢的資料項: ");
	scanf("%d", &key);
	
	// 呼叫函式binarySearch()在陣列a中查詢指定資料項key,並返回查詢結果給index
    // 補足程式碼① 
    index=binarySearch(a,N,key);
	
	if(index>=0) 
		printf("%d在陣列中,下標為%d\n", key, index);
	else
		printf("%d不在陣列中\n", key); 
   
   return 0;
}

//函式功能描述:
//使用二分查詢演算法在陣列x中查詢特定值item,陣列x大小為n 
// 如果找到,返回其下標 
// 如果沒找到,返回-1 
int binarySearch(int x[], int n, int item) {
	int low, high, mid;
	
	low = 0;
	high = n-1;
	
	while(low <= high) {
		mid = (low+high)/2;
		
		if (x[mid]==item)
			return mid;
		else if(x[mid]>item)
			high = mid - 1;
		else
			low = mid + 1;
	}
	
	return -1;
}

2、

// 練習:使用二分查詢,在一組有序元素中查詢資料項
//  形參是指標變數,實參是陣列名 
#include  <stdio.h>

const int N=5;

int binarySearch(int *x, int n, int item); // 函式宣告 

int main() {
	int a[N]={2,7,19,45,66};
	int i,index, key;
	
	printf("陣列a中的資料:\n");
	for(i=0;i<N;i++)
	   printf("%d ",a[i]);
	printf("\n");
	
	printf("輸入待查詢的資料項: ");
	scanf("%d", &key);
	
	// 呼叫函式binarySearch()在陣列a中查詢指定資料項key,並返回查詢結果給index
    // 補足程式碼① 
    index=binarySearch(a,N,key);
	
	if(index>=0) 
		printf("%d在陣列中,下標為%d\n", key, index);
	else
		printf("%d不在陣列中\n", key); 
   
   return 0;
}

//函式功能描述:
//使用二分查詢演算法在從x中查詢特定值item,陣列x大小為n 
// 如果找到,返回其下標 
// 如果沒找到,返回-1 
int binarySearch(int *x, int n, int item) {
	int low, high, mid;
	
	low = 0;
	high = n-1;
	
	while(low <= high) {
		mid = (low+high)/2;
		
		if ( item == *(x+mid) )
			return mid;
		else if(item < *(x+mid))
			high=mid-1;
		else
			low=mid+1;
	}
	
	return -1;
}

實驗任務6

// 練習:使用選擇法對字串按字典序排序
#include <stdio.h>

const int N = 5;

void selectSort(char str[][20], int n ); // 函式宣告,形參str是二維陣列名 
int main() {
	char name[][20] = {"Bob", "Bill", "Joseph", "Taylor", "George"};
	int i;
	
	printf("輸出初始名單:\n");
	for(i=0; i<N; i++)
		printf("%s\n", name[i]);
		
	selectSort(name, N);  // 呼叫選擇法對name陣列中的字串排序
	
	printf("按字典序輸出名單:\n");
	for(i=0; i<N; i++)
		printf("%s\n", name[i]);
	
	return 0;
} 

// 函式定義
// 函式功能描述:使用選擇法對二維陣列str中的n個字串按字典序排序 
void selectSort(char str[][20], int n) {
	int i,j,b,c,m;
	char a[20];
	for(i=0;i<=n;i++){
		m=i;
		for(j=i+1;j<n;j++){
			for(b=0;b<20;b++){
				if(str[m][b]<str[j][b])
					break;
				if(str[m][b]>str[j][b]){
					m=j;
					break;
				}
					
			}
		}
	} 
	if(m!=i){
		for(c=0;c<20;c++){
			a[c]=str[i][c];
			str[i][c]=str[m][c];
			str[m][c]=a[c];
		}
	}
}