21、下列給定程式中函式fun的功能是:將m(1≤m≤10)個字串連接起來,組成一個新串,放入pt所指存盤區中,例如:把三個串"abc"、"CD"、"EF"連接起來,結果是"abcCDEF",
請改正程式中的錯誤,使它能得出正確的結果,
注意:不要改動main函式,不得增行或刪行,也不得更改程式的結構!
#include <stdio.h> #include <string.h> void fun ( char str[][10], int m, char *pt ) { /************found************/ Int k, q, i ; for ( k = 0; k < m; k++ ) { q = strlen ( str [k] ); for (i=0; i<q; i++) /************found************/ pt[i] = str[k,i] ; pt += q ; pt[0] = 0 ; } } int main( ) { int m, h ; char s[10][10], p[120] ; printf( "\nPlease enter m:" ) ; scanf("%d", &m) ; gets(s[0]) ; printf( "\nPlease enter %d string:\n", m ) ; for ( h = 0; h < m; h++ ) gets( s[h]) ; fun(s, m, p) ; printf( "\nThe result is : %s\n", p) ; return 0; }
22、下列給定程式中,函式fun的功能是:依次取出字串中所有的數字字符,形成新的字串,并取代原字串,
請改正函式fun中的錯誤,使它能得出正確的結果,
注意:不得增行或刪行,也不得更改程式的結構,
#include <stdio.h> void fun(char *s) { int i,j; for(i=0,j=0; s[i]!= '\0'; i++) if(s[i]>= '0'&&s[i]<= '9') /*************found**************/ s[j]=s[i]; /*************found**************/ s[j]=”\0”; } int void main() { char item[80]; printf("\nEnter a string: ");gets(item); printf("\nThe string is:%s\n",item); fun(item); printf("\nThe string of changing is :%s\n",item); return 0; }
23、由N個有序整陣列成的數列已放在一維陣列中,下列給定程式中函式fun的功能是:利用折半查找法查找整數m在陣列中的位置,若找到,回傳其下標值;否則,回傳-1,
折半查找的基本演算法是:每次查找前先確定陣列中待查的范圍low和high(low<high),然后用m與中間位置(mid)上元素的值進行比較,如果m的值大于中間位置元素的值,則下一次的查找范圍落在中間位置之后的元素中;反之,下一次的查找范圍落在中間位置之前的元素中,直到low>high,查找結束,
請改正程式中的錯誤,使它能得出正確的結果,
注意:不得增行或刪行,也不得更改程式的結構,
#include <stdio.h> #define N 10 /************found************/ void fun(int a[], int m ) { int low=0,high=N-1,mid; while(low<=high) { mid=(low+high)/2; if(m<a[mid]) high=mid-1; /************found************/ else If(m > a[mid]) low=mid+1; else return(mid); } return(-1); } int main() {
int i,a[N]={-3,4,7,9,13,45,67,89,100,180 },k,m; printf("a陣列中的資料如下:"); for(i=0;i<N;i++) printf("%d ", a[i]); printf("Enter m: "); scanf("%d",&m); k=fun(a,m); if(k>=0) printf("m=%d,index=%d\n",m,k); else printf("Not be found!\n"); return 0; }
24、下列給定程式中,函式fun的功能是:對N名學生的學習成績,按從高到低的順序找出前m(m≤10)名學生來,并將這些學生的資料存放在一個動態分配的連續存盤區中,此存盤區的首地址作為函式值回傳,
請改正程式中的錯誤,使它能得出正確的結果,
注意:不得增行或刪行,也不得更改程式的結構,
#include <stdlib.h> #include <string.h> #include <stdio.h> #include <malloc.h> #define N 10 typedef struct ss { char num[10]; int s; } STU; STU *fun(STU a[], int m) { STU b[N],*t; int i, j,k; /*************found**************/ *t=calloc(m,sizeof(STU)); for(i=0;i<N;i++) b[i]=a[i]; for(k=0;k<m;k++) { for (i=j=0;i<N;i++) if(b[i].s>b[j].s) j=i; /*************found**************/ t[k].num=b[j].num; t[k].s=b[j].s; b[j].s=0; } return t; } outresult(STU a[],FILE *pf) { int i; for(i=0;i<N;i++) fprintf(pf, "No=%s Mark=%d\n ",a[i].num, a[i].s); fprintf(pf, "\n\n "); } int main() { STU a[N]={{ "A01 ",81},{ "A02 ",89},{ "A03 ",66},{ "A04 ",87},{ "A05 ",77}, { "A06 ",90},{ "A07 ",79},{ "A08 ",61},{ "A09 ",80},{ "A10 ",71}}; STU *pOrder; int i, m; printf("*****THE RESULT*****\n"); outresult(a,stdout); printf("\nGive the number of the students who have better score: "); scanf("%d",&m); while(m>10) {
printf("\nGive the number of the students who have better score: "); scanf("%d",&m); } pOrder=fun(a,m); printf("***** THE RESULT*****\n"); printf("The top :\n"); for(i=0;i<m;i++) printf("%s %d\n",pOrder[i].num, pOrder[i].s); free(pOrder); return 0; }
25、給定程式MODI1.C中,函式fun的功能是:在有n名學生,2門課成績的結構體陣列std中,計算出第1門課程的平均分,作為函式值回傳,例如,主函式中給出了4名學生的資料,則程式運行的結果為:第1門課程的平均分是:76.125000
請改正函式fun中指定部位的錯誤,使它能得出正確的結果,
注意:不要改動main函式,不得增行或刪行,也不得更改程式的結構,
#include <stdio.h> typedef struct { char num[8]; double score[2]; }STU ; double fun(STU std[], int n) { int i; /**********found**********/ double sum ; /**********found**********/ for(i=0; i<2 ; i++) /**********found**********/ sum += std[i].score[1]; return sum/n; } int main() { STU std[ ]={ "N1001", 76.5,82.0 ,"N1002", 66.5,73.0, "N1005", 80.5,66.0,"N1006", 81.0,56.0 }; printf("第1門課程的平均分是:%lf\n", fun(std,4) ); return 0; }
26、下列給定程式中函式fun的功能是:輸出M×M整數方陣,然后求兩條對角線上元素之和,并作為函式值回傳,
請改正程式中的錯誤,使它能得出正確的結果,
注意:不得增行或刪行,也不得更改程式的結構!
#include <stdio.h> #define M 5 /************found************/ int fun(int n, int xx[][]) { int i, j, sum=0; printf( "\nThe %d x %d matrix:\n", M, M ); for(i = 0; i < M; i++) { for(j = 0; j < M; j++) /************found************/ printf("%f ", xx[i][j]); printf("\n"); } for(i = 0 ; i < n ; i++) sum += xx[i][i]+xx[i][ n-i-1 ]; return( sum ); } int main( ) { int aa[M][M]={{1,2,3,4,5},{4,3,2,1,0},{6,7,8,9,0},{9,8,7,6,5},{3,4,5,6,7}}; printf("\nThe sum of all elements on 2 diagnals is %d.",fun(M, aa)); return 0; }
27、下列給定程式中,函式fun的功能是:計算整數n的階乘,
請改正程式中的錯誤,使它能得出正確的結果,
注意:不要改動main函式,不得增行或刪行,也不得更改程式的結構,
#include <stdio.h> double fun(int n) { double result=1.0; while(n>1 && n<170) /*************found**************/ Result *=--n; /*************found**************/ return; } int main() { int n; printf("Enter an integer: "); scanf("%d",&n); printf("\n%d!=%1g\n ",n,fun(n)); return 0; }
28、下列給定程式中,函式fun的功能是:根據輸入的三個邊長(整型值),判斷能否構成三角形,若能構成等邊三角形,則回傳3;若是等腰三角形,則回傳2;若能構成三角形則回傳1;若不能,則回傳0,
請改正程式中的錯誤,使它能得出正確的結果,
注意:不要改動main函式,不得增行或刪行,也不得更改程式的結構!
#include <stdio.h> #include <math.h> int fun(int a,int b,int c) { if(a+b>c&&b+c>a&&a+c>b) {if(a==b && b==c) /*************found**************/ return 1; else if(a==b||b==c||a==c) return 2; /*************found**************/ else return 3; } else return 0; } int main() { int a,b,c,shape; printf("\nInput a,b,c: "); scanf("%d%d%d",&a,&b,&c); printf("\na=%d, b=%d, c=%d\n",a,b,c); shape=fun(a,b,c); printf("\nThe shape :%d\n",shape); return 0; }
29、下列給定的程式中,函式fun的功能是:計算并輸出k以內最大的10個能被13或17整除的自然數之和,k的值由主函式傳入,若k的值為500,則函式的值為4622,
請改正程式中的錯誤,使它能得出正確的結果,
注意:不要改動main函式,不得增行或刪行,也不得更改程式的結構!
#include <stdio.h> int fun(int k) { int m=0,mc=0, j; while((k>=2) && (mc<10)) { /*************found**************/ if((k%13=0)||(k%17=0)) { m=m+k;mc++; } k--; /*************found**************/ return m; } int main() { printf("%d\n ",fun(500)); return 0; }
30、給定程式中函式fun的功能是:首先把b所指字串中的字符按逆序存放,然后將a所指字串中的字符和b所指字串中的字符,按排列的順序交叉合并到c所指陣列中,
過長的剩余字符接在c所指的陣列的尾部,
例如,當a所指字串中的內容為"abcdefg",b所指字串中的內容為"1234"時,c所指陣列中的內容應為"a4b3c2d1efg";而當a所指字串中的內容為"1234",
b所指字串的內容為"abcdefg"時,c所指陣列中的內容應該為"1g2f3e4dcba",
請改正程式中的錯誤,使它能得出正確的結果,
注意:不要改動main函式,不得增行或刪行,也不得更改程式的結構!
#include <stdio.h> #include <string.h> void fun(char *a,char *b,char *c) { int i,j;char ch; i=0; j=strlen(b)-1; /************found************/ while(i > j) { ch=b[i]; b[i]=b[j]; b[j]=ch; i++; j--; } while ( *a || *b ) { /************found************/ If ( *a ) { *c = *a; c++; a++; } if ( *b ) { *c = *b; c++; b++; } } *c = 0; } int main() { char s1[100],s2[100],t[200]; printf("\nEnter s1 string : "); scanf("%s",s1); printf("\nEnter s2 string : "); scanf("%s",s2); fun( s1, s2, t ); printf("\nThe result is : %s\n",t); return 0; }
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/535122.html
標籤:C
