第 1 頁:填空題 |
第 2 頁:改錯題 |
第 3 頁:程序題 |
例如, 一維數(shù)組中的數(shù)據(jù)是: 2 2 2 3 4 4 5 6 6 6 6 7 7 8 9 9 10 10 10。
刪除后,數(shù)組中的內(nèi)容應(yīng)該是: 2 3 4 5 6 7 8 9 10。
注意:部分源程序在文件PROG1.C中。
請勿改動主函數(shù)main和其它函數(shù)中的任何內(nèi)容, 僅在函數(shù)fun的花括號中填入你編寫的若干語句。
給定源程序:
#include
#define N 80
int fun(int a[], int n)
{
}
main()
{int a[N]={2,2,2,3,4,4,5,6,6,6,6,7,7,8,9,9,10,10,10, 10},i,n=20;void NONO ();
printf("The original data :\n");
for(i=0; i n=fun(a,n); printf("\n\nThe data after deleted :\n"); for(i=0;i NONO(); } void NONO () {/* 請在此函數(shù)內(nèi)打開文件,輸入測試數(shù)據(jù),調(diào)用 fun 函數(shù),輸出數(shù)據(jù),關(guān)閉文件。 */ FILE *rf, *wf; int a[N], n, i, j ; rf = fopen("in.dat","r"); wf = fopen("out.dat","w"); for(i = 0 ; i < 5 ; i++) { fscanf(rf, "%d", &n); for(j = 0 ; j < n ; j++) fscanf(rf, "%d", &a[j]); n = fun(a, n); for(j = 0 ; j < n ; j++) fprintf(wf, "%4d", a[j]); fprintf(wf, "\n"); } fclose(rf); fclose(wf); } 參考答案: int fun(int a[], int n) { int i, j = 1, k = a[0] ; for(i = 1 ; i < n ; i++) if(k != a[i]) { a[j++]=a[i] ; k = a[i] ; } a[j] = 0 ; return j ; }
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |