<source id="v77gz"></source>
    <u id="v77gz"><p id="v77gz"></p></u>

      <samp id="v77gz"></samp>

      <var id="v77gz"><td id="v77gz"><ins id="v77gz"></ins></td></var>

      <video id="v77gz"></video>
      <source id="v77gz"></source>
    1. 江蘇省高校計算機等級考試命題研究院 江蘇省高校計算機等級考試輔導
      全國計算機二級C題目第21--30套

       

      本題目如果下載后發現有錯誤的地方,請聯系網站管理員:QQ121431055

       

      考試時,上機題目有三套,基本操作題、簡單應用題、綜合應用題

       

      21套:

      給定程序中,函數fun的功能是:計算形參x所指數組中N個數的平均值(規定

      所有數均為正數),將所指數組中大于平均值的數據移至數組的前部,小于等于平

      均值的數據移至x所指數組的后部,平均值作為函數值返回,在主函數中輸出平均

      值和移動后的數據。

      例如,有10個正數:46 30 32 40 6 17 45 15 48 26,平均值為:

      30.500000

      移動后的輸出為:46 32 40 45 48 30 6 17 15 26

      請在程序的下劃線處填入正確的內容并把下劃線刪除, 使程序得出正確的結

      果。

      注意:源程序存放在考生文件夾下的BLANK1.C中。

      不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      #include

      #define N 10

      double fun(double *x)

      { int i, j; double s, av, y[N];

      s=0;

      for(i=0; i

      /**********found**********/

      av=__1__;

      for(i=j=0; i

      if( x[i]>av ){

      /**********found**********/

      y[__2__]=x[i]; x[i]=-1;}

      for(i=0; i

      /**********found**********/

      if( x[i]!= __3__) y[j++]=x[i];

      for(i=0; i

      return av;

      }

      main()

      { int i; double x[N];

      for(i=0; i4.0f ",x[i]);}

      printf("\n");

      printf("\nThe average is: %f\n",fun(x));

      printf("\nThe result :\n",fun(x));

      for(i=0; i5.0f ",x[i]);

      printf("\n");

      }

      解題思路:

      第一處:計算N個數的平均值,所以應填:s/N。

      第二處:利用for循環語句,把數組x中大于平均值的數,依次存放到數組y中,同時把數組

      x上的該數置為-1,其中位置由變量j來控制,所以應填:j++。

       

       

      第三處:再利用循環把不是-1的數,依次仍存放到數組y中,所以應填:-1。

      ***************************************************

      給定程序MODI1.C的功能是:讀入一個英文文本行,將其中每個單詞的第一個

      字母改成大寫,然后輸出此文本行(這里的“單詞”是指由空格隔開的字符串)。

      例如,若輸入:I am a student to take the examination.,

      則應輸出:I Am A Student To Take The Examination.。

      請改正程序中的錯誤,使程序能得出正確的結果。

      注意:不要改動 main 函數,不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      #include

      /************found************/

      include

      /************found************/

      upfst ( char p )

      { int k=0;

      for ( ; *p; p++ )

      if ( k )

      { if ( *p == ' ' ) k = 0; }

      else if ( *p != ' ' )

      { k = 1; *p = toupper( *p ); }

      }

      main( )

      { char chrstr[81];

      printf( "\nPlease enter an English text line: " ); gets( chrstr );

      printf( "\n\nBefore changing:\n %s", chrstr );

      upfst( chrstr );

      printf( "\nAfter changing:\n %s\n", chrstr );

      }

      解題思路:

      第一處:包含頭文件的標識錯誤,在include前漏寫了#。

      第二處:由于傳入的參數是字符串,所以應為upfst(char *p)。

      ***************************************************

      程序定義了N×N的二維數組,并在主函數中賦值。請編寫函數fun,函數的功

      能是:求出數組周邊元素的平均值并作為函數值返給主函數中的s。

      例如:a 數組中的值為

      |0 1 2 7 9|

      |1 9 7 4 5|

      a = |2 3 8 3 1|

      |4 5 6 8 2|

      |5 9 1 4 1|

      則返回主程序后s的值應為: 3.375。

      注意: 部分源程序存在文件PROG1.C文件中。

      請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括號中填入

      你編寫的若干語句。

      給定源程序:

      #include

       

       

      #include

      #define N 5

      double fun ( int w[][N] )

      {

      }

      main ( )

      { int a[N][N]={0,1,2,7,9,1,9,7,4,5,2,3,8,3,1,4,5,6,8,2,5,9,1,4,1};

      int i, j;

      double s ;

      printf("***** The array *****\n");

      for ( i =0; i

      { for ( j =0; j

      { printf( "M", a[i][j] ); }

      printf("\n");

      }

      s = fun ( a );

      printf ("***** THE RESULT *****\n");

      printf( "The sum is : %lf\n",s );

      NONO( );

      }

       

      解題思路:

      本題是統計二維數組周邊元素值的平均值,但要注意的是不要重復計算四個角上的元素值。

      參考答案:

       

      double fun ( int w[][N] )

      {

      int i, j, n=0;

      double sum=0;

      for ( i =0; i

      sum+=w[0][i]+w[N-1][i]; n+=2;

      }

      for ( i =1; i

       

       

      sum +=w[i][0]+w[i][N-1];

      n+=2;

      }

      return sum/n;

      }

       

      ※※※※※※※※※※※※※※※※※※※※※※※※※

      22套:

      給定程序中,函數fun的功能是:將自然數110以及它們的平方根寫到名為

      myfile3.txt的文本文件中,然后再順序讀出顯示在屏幕上。

      請在程序的下劃線處填入正確的內容并把下劃線刪除,使程序得出正確的結

      果。

      注意:源程序存放在考生文件夾下的BLANK1.C中。

      不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      #include

      int fun(char *fname )

      { FILE *fp; int i,n; float x;

      if((fp=fopen(fname, "w"))==NULL) return 0;

       

       

      for(i=1;i<=10;i++)

      /**********found**********/

      fprintf(___1___,"%d %f\n",i,sqrt((double)i));

      printf("\nSucceed!!\n");

      /**********found**********/

      ___2___;

      printf("\nThe data in file :\n");

      /**********found**********/

      if((fp=fopen(___3___,"r"))==NULL)

      return 0;

      fscanf(fp,"%d%f",&n,&x);

      while(!feof(fp))

      { printf("%d %f\n",n,x); fscanf(fp,"%d%f",&n,&x); }

      fclose(fp);

      return 1;

      }

      main()

      { char fname[]="myfile3.txt";

      fun(fname);

      }

      解題思路:

      本題要求所求出的數寫入到指定的文件中保存。程序中共有三處要填上適當的內容,使程

      序能運行出正確的結果。

      第一處:int fprintf(FILE *stream, const char *format [,argument, ]); 因此本處

      只能填寫文件流的變量fp。

      第二處:由于文件打開寫操作,所以必須要關閉,因此,只能填寫關閉文件的函數

      fclose(fp)。

      第三處:由于本題要把剛寫入文件中的數據重新顯示出來,讀方式已經給出,但沒有給出

      文件名,所以本處只能寫文件名變量fname或者直接給出文件名"myfile3.dat"。

      ***************************************************

      給定程序MODI1.Cfun函數的功能是:將n個無序整數從小到大排序。

      請改正程序中的錯誤,使它能得出正確的結果。

      注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      #include

      fun ( int n, int *a )

      { int i, j, p, t;

      for ( j = 0; j

      { p = j;

      /************found************/

      for ( i=j+1; i

      if ( a[p]>a[i] )

      /************found************/

      t=i;

      if ( p!=j )

      { t = a[j]; a[j] = a[p]; a[p] = t; }

       

       

      }

      }

      putarr( int n, int *z )

      { int i;

      for ( i = 1; i <= n; i++, z++ )

      { printf( "M", *z );

      if ( !( i ) ) printf( "\n" );

      } printf("\n");

      }

      main()

      { int aa[20]={9,3,0,4,1,2,5,6,8,10,7}, n=11;

      printf( "\n\nBefore sorting %d numbers:\n", n ); putarr( n, aa );

      fun( n, aa );

      printf( "\nAfter sorting %d numbers:\n", n ); putarr( n, aa );

      }

      解題思路:

      第一處:for循環的終止值應該或者是<=n-1。

      第二處:使用臨時變量p來保存最小值位置i,所以應改為:p=i;。

      ***************************************************

      函數fun的功能是: 將兩個兩位數的正整數a、b合并形成一個整數放在c中。

      合并的方式是: a數的十位和個位數依次放在c數的個位和百位上, b數的十位

      和個位數依次放在c數的十位和千位上。

      例如, a=45, b=12, 調用該函數后, c=2514。

      注意: 部分源程序存在文件PROG1.C中。數據文件IN.DAT中的數據不得修改。

      請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括號中填入

      你編寫的若干語句。

      給定源程序:

      #include

      void fun(int a, int b, long *c)

      {

      }

      main()

      { int a,b; long c;

      printf("Input a, b:");

      scanf("%d,%d", &a, &b);

      fun(a, b, &c);

      printf("The result is: %ld\n", c);

      NONO();

      }

       

      解題思路:

      本題是給出兩個兩位數的正整數分別取出各位上的數字,再按條件組成一個新數。

      a十位數字的方法:a/10

      a個位數字的方法:a

      參考答案:

      void fun(int a, int b, long *c)

      {

      *c=(b)*1000+(a)*100+(b/10)*10+(a/10);

      }

       

      ※※※※※※※※※※※※※※※※※※※※※※※※※

      23套:

      給定程序中,函數fun的功能是:找出N×N矩陣中每列元素中的最大值,并按

      順序依次存放于形參b所指的一維數組中。

      請在程序的下劃線處填入正確的內容并把下劃線刪除, 使程序得出正確的結

      果。

      注意:源程序存放在考生文件夾下的BLANK1.C中。

      不得增行或刪行,也不得更改程序的結構!

      給定源程序:

       

       

      #include

      #define N 4

      void fun(int (*a)[N], int *b)

      { int i,j;

      for(i=0; i

      /**********found**********/

      b[i]= __1__;

      for(j=1; j

      /**********found**********/

      if(b[i] __2__ a[j][i]) b[i]=a[j][i];

      }

      }

      main()

      { int x[N][N]={ {12,5,8,7},{6,1,9,3},{1,2,3,4},{2,8,4,3} },y[N],i,j;

      printf("\nThe matrix :\n");

      for(i=0;i

      { for(j=0;j

      printf("\n");

      }

      /**********found**********/

      fun(__3__);

      printf("\nThe result is:");

      for(i=0; iprintf("\n");

      }

      解題思路:

      第一處:把每列的第1值賦值給b[i],所以應填:a[0][i]。

      第二處:如果b[i]值小于a[j][i]的值,則把a[j][i]重新賦值給b[i]中,保存最大的值,

      所以應填:<。

      第三處:在主函數中,x是存放矩陣數據,y是存放每列的最大值,所以應填:x,y。

      ***************************************************

      給定程序MODI1.C中函數fun的功能是: 交換主函數中兩個變量的值。例如:

      若變量a中的值原為8,b中的值為3。程序運行后a中的值為3, b中的值為8。

      請改正程序中的錯誤, 使它能計算出正確的結果。

      注意: 不要改動 main 函數, 不得增行或刪行, 也不得更改程序的結構!

      給定源程序:

      #include

      /*********found**********/

      int fun(int x,int y)

      {

      int t;

      /*********found**********/

      t=x;x=y;y=t;

      }

      main()

      {

      int a,b;

       

       

      a=8;b=3;

      fun(&a,&b);

      printf("%d, %d\n",a,b);

      }

      解題思路:

      第一處:函數形參定義不正確,在定義第2個形參時,也應加上int。由于通過該函數實現

      兩數交換,在C語言中,必須交換地址中的值,所以應定義為int *x,int *y。

      第二處:要交換地址中的值,不能交換地址,必須指定地址中的值,因此應改為

      t=*x;*x=*y;*y=t;。

      ***************************************************

      編寫函數fun, 函數的功能是求出小于或等于lim的所有素數并放在aa數組中,

      函數返回所求出的素數的個數。函數fun中給出的語句僅供參考。

      注意:部分源程序在文件PROG1.C中。

      請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括號中填入

      你編寫的若干語句。

      給定源程序:

      #include

      #define MAX 100

      int fun(int lim, int aa[MAX])

      {

      /* 以下代碼僅供參考 */

      int i,j,k=0;

      /* 其中變量k用于統計素數個數 */

      for(i=2;i<=lim;i++)

      {

      /* 以下完成判斷aa數組中小于或等于lim的素數并統計個數 */

      }

      return k;

      }

      main()

      {

      int limit, i, sum;

      int aa[MAX] ;

      printf("輸入一個整數");

      scanf("%d", &limit);

      sum=fun(limit, aa);

      for(i=0 ; i < sum ; i++) {

      if(i % 10 == 0 && i != 0) printf("\n") ;

      printf("]", aa[i]) ;

      }

      NONO();

      }

       

      解題思路:

      本題是考察考生如何判斷一個數是素數,再求出所有小于lim數的素數并存入數組aa中保

      存,最后由形參aa返回,素數的個數由函數值返回。

      參考答案:

       

      int fun(int lim, int aa[MAX])

      {

      /* 以下代碼僅供參考 */

      int i,j,k=0;

      /* 其中變量k用于統計素數個數 */

      for(i=2;i<=lim;i++)

      {

      /* 以下完成判斷aa數組中小于或等于lim的素數并統計個數 */

      for(j = 2 ; j <= (i/2) ; j++)

      if(i % j == 0) break;

      if(j > (i/2)) aa[k++] = i;

      }

      return k;

      }

       

      ※※※※※※※※※※※※※※※※※※※※※※※※※

      24套:

      程序通過定義學生結構體變量,存儲了學生的學號、姓名和3門課的成績。函

      fun的功能是將形參a中的數據進行修改,把修改后的數據作為函數值返回主函數

      進行輸出。

      例如:傳給形參a的數據中,學號、姓名、和三門課的成績依次是:10001、

      "ZhangSan"、95、80、88,修改后的數據應為:10002、"LiSi"、96、81、89。

      請在程序的下劃線處填入正確的內容并把下劃線刪除, 使程序得出正確的結

      果。

      注意:源程序存放在考生文件夾下的BLANK1.C中。

      不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      #include

      struct student {

      long sno;

      char name[10];

      float score[3];

      };

      /**********found**********/

      __1__ fun(struct student a)

      { int i;

      a.sno = 10002;

      /**********found**********/

      strcpy(__2__, "LiSi");

      /**********found**********/

      for (i=0; i<3; i++) __3__+= 1;

      return a;

      }

      main()

      { struct student s={10001,"ZhangSan", 95, 80, 88}, t;

      int i;

      printf("\n\nThe original data :\n");

      printf("\nNo: %ld Name: %s\nScores: ",s.sno, s.name);

      for (i=0; i<3; i++) printf("%6.2f ", s.score[i]);

      printf("\n");

      t = fun(s);

      printf("\nThe data after modified :\n");

       

       

      printf("\nNo: %ld Name: %s\nScores: ",t.sno, t.name);

      for (i=0; i<3; i++) printf("%6.2f ", t.score[i]);

      printf("\n");

      }

      解題思路:

      本題是對結構體變量中的值進行修改并通過函數值返回。

      第一處:必須定義結構返回類型,所以應填:struct student。

      第二處:對姓名進行修改,所以應填:a.name。

      第三處:分別對成績增加1分,所以應填:a.score[i]。

      ***************************************************

      假定整數數列中的數不重復,并存放在數組中。給定程序MODI1.C中函數fun

      的功能是:刪除數列中值為x的元素。n中存放的是數列中元素的個數。

      請改正程序中的錯誤,使它能得出正確結果。

      注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構。

      給定源程序:

      #include

      #define N 20

      fun(int *a,int n,int x)

      { int p=0,i;

      a[n]=x;

      while( x!=a[p] )

      \TAB p=p+1;

      /**********found**********/

      if(P==n) return -1;

      else

      { for(i=p;i

      /**********found**********/

      \TAB a[i+1]=a[i];

      return n-1;

      }

      }

      main()

      { int w[N]={-3,0,1,5,7,99,10,15,30,90},x,n,i;

      n=10;

      printf("The original data :\n");

      for(i=0;i

      printf("\nInput x (to delete): "); scanf("%d",&x);

      printf("Delete : %d\n",x);

      n=fun(w,n,x);

      if ( n==-1 ) printf("***Not be found!***\n\n");

      else

      { printf("The data after deleted:\n");

      for(i=0;i

      }

      }

      解題思路:

      第一處: 條件語句中的小寫p錯寫成大寫P了。

       

       

      第二處: 刪除元素,應該是后面位置的元素值賦值給前面的位置上,所以應改為:

      a[i]=a[i+1];。

      ***************************************************

      學生的記錄由學號和成績組成,N名學生的數據已在主函數中放入結構體數組

      s, 請編寫函數fun,它的功能是:把分數最低的學生數據放在b所指的數組中,

      注意:分數最低的學生可能不止一個,函數返回分數最低的學生的人數。

      注意: 部分源程序在文件PROG1.C文件中。

      請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括號中填入

      你編寫的若干語句。

      給定源程序:

      #include

      #define N 16

      typedef struct

      { char num[10];

      int s;

      } STREC;

      int fun( STREC *a, STREC *b )

      {

      }

      main()

      { STREC s[N]={{"GA05",85},{"GA03",76},{"GA02",69},{"GA04",85},

      \TAB \TAB {"GA01",91},{"GA07",72},{"GA08",64},{"GA06",87},

      \TAB \TAB {"GA015",85},{"GA013",91},{"GA012",64},{"GA014",91},

      \TAB \TAB {"GA011",91},{"GA017",64},{"GA018",64},{"GA016",72}};

      STREC h[N];

      int i,n;FILE *out ;

      n=fun( s,h );

      printf("The %d lowest score :\n",n);

      for(i=0;i

      printf("%s M\n",h[i].num,h[i].s);

      printf("\n");

      out = fopen("c:\\test\\out.dat","w") ;

      fprintf(out, "%d\n",n);

      for(i=0;i

      fprintf(out, "M\n",h[i].s);

      fclose(out);

      }

      解題思路:

      本題是把符合條件的學生記錄存入到另一個結構體,人數通過函數返回,記錄由實參b返回。

      1. 符合條件的學生人數存在變量j(初始值為0)中,最后返回其值。

      2. 利用for循環語句,依次判斷是否符合條件,如果成績相等,則把記錄存入b中,人數j

      1;如果當前成績a[i].s小于最低成績min,那么人數重新初始化為0,把當前成績存入最低成

      績中,人數j1。

      3. 直至循環結束為止。

      參考答案:

       

      int fun( STREC *a, STREC *b )

      {

      int i, j = 0, min=a[0].s ;

      for(i = 0 ; i < N; i++) {

      if(min > a[i].s) {

      j = 0 ; b[j++] = a[i] ; min = a[i].s ;

      }

      else if(min == a[i].s)

      b[j++] = a[i] ;

      }

      return j ;

      }

       

      ※※※※※※※※※※※※※※※※※※※※※※※※※

      25套:

      人員的記錄由編號和出生年、月、日組成,N名人員的數據已在主函數中存入

      結構體數組std中,且編號唯一。函數fun的功能是:找出指定編號人員的數據,

      作為函數值返回,由主函數輸出,若指定編號不存在,返回數據中的編號為空串。

      請在程序的下劃線處填入正確的內容并把下劃線刪除,使程序得出正確的結

      果。

      注意:源程序存放在考生文件夾下的BLANK1.C中。

      不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      #include

      #define N 8

       

       

      typedef struct

      { char num[10];

      int year,month,day ;

      }STU;

      /**********found**********/

      ___1___ fun(STU *std, char *num)

      { int i; STU a={"",9999,99,99};

      for (i=0; i

      /**********found**********/

      if( strcmp(___2___,num)==0 )

      /**********found**********/

      return (___3___);

      return a;

      }

      main()

      { STU std[N]={ {"111111",1984,2,15},{"222222",1983,9,21},{"333333",1984,9,1},

      {"444444",1983,7,15},{"555555",1984,9,28},{"666666",1983,11,15},

      {"777777",1983,6,22},{"888888",1984,8,19}};

      STU p; char n[10]="666666";

      p=fun(std,n);

      if(p.num[0]==0)

      printf("\nNot found !\n");

      else

      { printf("\nSucceed !\n ");

      printf("%s %d-%d-%d\n",p.num,p.year,p.month,p.day);

      }

      }

      解題思路:

      本題是要求從給定的人員數據中找出編號相同的記錄數據。

      第一處:從返回值來看,是返回一個結構型的值,所以應填:STU。

      第二處:判斷結構變量中的編號num是否相等,所以應填:stu[i].num。

      第三處:返回編號相等的記錄值,所以應填:std[i]。

      ***************************************************

      給定程序MODI1.C中函數fun的功能是:從s所指字符串中,找出與t所指字符

      串相同的子串的個數作為函數值返回。

      例如,當s所指字符串中的內容為:"abcdabfab",t所指字符串的內容為:

      "ab",則函數返回整數3。

      請改正程序中的錯誤,使它能得出正確的結果。

      注意:不要改動main 函數,不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      #include

      int fun (char *s, char *t)

      {

      int n; char *p , *r;

      n = 0;

      while ( *s )

       

       

      { p = s; r = t;

      while ( *r )

      if ( *r == *p ) {

      /************found************/

      r++; p++

      }

      else break;

      /************found************/

      if ( r == '\0' )

      n++;

      s++;

      }

      return n;

      }

      main()

      {

      char s[100], t[100]; int m;

      printf("\nPlease enter string S:"); scanf("%s", s);

      printf("\nPlease enter substring t:"); scanf("%s", t);

      m = fun( s, t);

      printf("\nThe result is: m = %d\n", m);

      }

      解題思路:

      第一處:語句后缺少分號。

      第二處:判斷r的當前字符是否是字符串結束符,所以應改為:if(*r==0)。

      ***************************************************

      函數fun的功能是:將s所指字符串中ASCII值為偶數的字符刪除,串中剩余字

      符形成一個新串放在t所指的數組中。

      例如,若s所指字符串中的內容為:"ABCDEFG12345",其中字符BASCII碼值

      為偶數、…、字符2ASCII碼值為偶數、… 都應當刪除,其它依此類推。最后t

      指的數組中的內容應是:"ACEG135"。

      注意: 部分源程序存在文件PROG1.C中。

      請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括號中填入

      你編寫的若干語句。

      給定源程序:

      #include

      #include

      void fun(char *s, char t[])

      {

      }

      main()

      {

      char s[100], t[100];

      printf("\nPlease enter string S:"); scanf("%s", s);

      fun(s, t);

      printf("\nThe result is: %s\n", t);

      NONO();

       

       

      }

       

      解題思路:

      本題是從一個字符串按要求生成另一個新的字符串。我們使用for循環語句來解決這個問

      題。

      參考答案:

      void fun(char *s, char t[])

      {

      int i, j = 0 ;

      for(i = 0 ; i < strlen(s); i++) if(s[i] % 2) t[j++] = s[i] ;

      t[j] = 0 ;

      }

       

      ※※※※※※※※※※※※※※※※※※※※※※※※※

      26

      給定程序中已建立一個帶有頭結點的單向鏈表,鏈表中的各結點按數據域遞

      增有序鏈接。函數fun的功能是:刪除鏈表中數據域值相同的結點,使之只保留一

      個。

      請在程序的下劃線處填入正確的內容并把下劃線刪除,使程序得出正確的結

      果。

      注意:源程序存放在考生文件夾下的BLANK1.C中。

      不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      #include

      #define N 8

      typedef struct list

      { int data;

      struct list *next;

      } SLIST;

      void fun( SLIST *h)

      { SLIST *p, *q;

      p=h->next;

      if (p!=NULL)

      { q=p->next;

      while(q!=NULL)

      { if (p->data==q->data)

      { p->next=q->next;

      /**********found**********/

      free(___1___);

      /**********found**********/

      q=p->___2___;

      }

      else

      { p=q;

      /**********found**********/

      q=q->___3___;

      }

      }

      }

      }

      SLIST *creatlist(int *a)

      { SLIST *h,*p,*q; int i;

      h=p=(SLIST *)malloc(sizeof(SLIST));

      for(i=0; i

      { q=(SLIST *)malloc(sizeof(SLIST));

       

       

      q->data=a[i]; p->next=q; p=q;

      }

      p->next=0;

      return h;

      }

      void outlist(SLIST *h)

      { SLIST *p;

      p=h->next;

      if (p==NULL) printf("\nThe list is NULL!\n");

      else

      { printf("\nHead");

      do { printf("->%d",p->data); p=p->next; } while(p!=NULL);

      printf("->End\n");

      }

      }

      main( )

      { SLIST *head; int a[N]={1,2,2,3,4,4,4,5};

      head=creatlist(a);

      printf("\nThe list before deleting :\n"); outlist(head);

      fun(head);

      printf("\nThe list after deleting :\n"); outlist(head);

      }

      解題思路:

      本題是考察考生對鏈表的操作,主要是解決刪除鏈表中數據域值相同的結點。程序中共有

      三處要填上適當的內容,使程序能運行出正確的結果。

      函數fun中使用兩個臨時結構指針變量pq對鏈表進行操作。首先p指向鏈表開始的next

      針,q指向pnext指針,再利用while循環語句來判斷指針q是否NULL,如果q指針是指向NULL,

      那么函數結束返回。如果不是NULL,那么就要判斷pqdata值是否相同,如果值相同,則要

      刪除該結點,然后繼續判斷下一結點值是相同,如果還相同,那么繼續刪除結點,直至不相同

      為止。如果兩個結點的值不相同,那么p就指向q,q指向qnext指針再繼續操作上述過程。

      刪除結點的方法是:先將pnext指針指向qnext指針,再釋放q指針指向的內存,最后把

      q指針再指向pnext指針就可以刪除一個鏈表中的結點了。

      第一處:釋放q指針所指的內存空間,應填q。

      第二處:q指針指向pnext指針,重新完成鏈接,應填next。

      第三處:兩個結點的值不相同,那么q就指向qnext指針,應填next。

      ***************************************************

      給定程序MODI1.C中函數fun的功能是:用選擇法對數組中的n個元素按從小到

      大的順序進行排序。

      請修改程序中的錯誤,使它能得出正確的結果。

      注意:不要改動main函數,不得增行和刪行,也不得更改程序的結構!

      給定源程序:

      #include

      #define N 20

      void fun(int a[], int n)

      { int i, j, t, p;

      for (j = 0 ;j < n-1 ;j++) {

      /************found************/

       

       

      p = j

      for (i = j;i < n; i++)

      if(a[i] < a[p])

      /************found************/

      p = j;

      t = a[p] ; a[p] = a[j] ; a[j] = t;

      }

      }

      main()

      {

      int a[N]={9,6,8,3,-1},i, m = 5;

      printf("排序前的數據:") ;

      for(i = 0;i < m;i++) printf("%d ",a[i]); printf("\n");

      fun(a,m);

      printf("排序后的數據:") ;

      for(i = 0;i < m;i++) printf("%d ",a[i]); printf("\n");

      }

      解題思路:

      第一處:語句后缺少分號。

      第二處:保存最小值的位置,所以應改為:p = i;。

      ***************************************************

      請編寫一個函數fun,它的功能是:求出1m之間(m)能被711整除的所有

      整數放在數組a中,通過n返回這些數的個數。例如,若傳送給m的值為50,則程序

      輸出:

      7 11 14 21 22 28 33 35 42 44 49

      注意: 部分源程序存在文件PROG1.C中。

      請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括號中填入

      你編寫的若干語句。

      給定源程序:

      #include

      #define M 100

      void fun ( int m, int *a , int *n )

      {

      }

      main( )

      { int aa[M], n, k;

      fun ( 50, aa, &n );

      for ( k = 0; k < n; k++ )

      if((k+1) ==0) printf("\n");

      else printf( "M", aa[k] );

      printf("\n") ;

      NONO( );

      }

       

      解題思路:

      本題是考察考生對某個數能被其他的數整除方式,并把符合條件的數存放在數組a中。

      我們給出的程序是使用for循環語句以及取模的方式來解決這個問題的。

      參考答案:

      #include

      #define M 100

      void fun ( int m, int *a , int *n )

      {

      int i ;

      *n=0 ;

      for(i=7 ; i<=m; i++)

      if((i % 7 == 0) || (i % 11 == 0)) a[(*n)++]=i ;

      }

       

      ※※※※※※※※※※※※※※※※※※※※※※※※※

      27套:

      給定程序中,函數fun的功能是:計算下式前n項的和作為函數值返回。

      例如,當形參n的值為10時,函數返回:9.612558。

      請在程序的下劃線處填入正確的內容并把下劃線刪除,使程序得出正確的結

      果。

      注意:源程序存放在考生文件夾下的BLANK1.C中。

      不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      double fun(int n)

      { int i; double s, t;

      /**********found**********/

      s=__1__;

      /**********found**********/

      for(i=1; i<=__2__; i++)

      { t=2.0*i;

      /**********found**********/

      s=s+(2.0*i-1)*(2.0*i+1)/__3__;

      }

      return s;

      }

      main()

      { int n=-1;

      while(n<0)

      { printf("Please input(n>0): "); scanf("%d",&n); }

      printf("\nThe result is: %f\n",fun(n));

      }

      解題思路:

      第一處:根據公式可知,累加和變量s,應置0。

      第二處:for循環的終止值應為形參n。

      第三處:根據公式以及函數體中t變量內容,所以應填:t*t。

      ***************************************************

      給定程序MODI1.C中函數 fun 的功能是:統計substr所指子字符串在str所指

      字符串中出現的次數。

      例如,若字符串為aaas lkaaas,子字符串為as,則應輸出2。

      請改正程序中的錯誤,使它能計算出正確的結果。

      注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

       

       

      fun (char *str,char *substr)

      { int i,j,k,num=0;

      /************found************/

      for(i = 0, str[i], i++)

      for(j=i,k=0;substr[k]==str[j];k++,j++)

      /************found************/

      If(substr[k+1]=='\0')

      { num++;

      break;

      }

      return num;

      }

      main()

      {

      char str[80],substr[80];

      printf("Input a string:") ;

      gets(str);

      printf("Input a substring:") ;

      gets(substr);

      printf("%d\n",fun(str,substr));

      }

      解題思路:

      第一處:循環for語句中應有分號。

      第二處:if錯寫成If。

      ***************************************************

      請編寫一個函數fun,它的功能是:根據以下公式求π的值(要求滿足精度

      0.0005, 即某項小于0.0005時停止迭代):

      π 1 1×2 1×2×3 1×2×3×4 1×2×…×n

      = 1++─—+────+──────+……+────────

      2 3 3×5 3×5×7 3×5×7×9 3×5×…×(2n+1)

      程序運行后,如果輸入精度0.0005,則程序輸出為3.14…。

      注意: 部分源程序存在文件PROG1.C文件中。

      請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括號中填

      入你編寫的若干語句。

      給定源程序:

      #include

      #include

      double fun ( double eps)

      {

      }

      main( )

      { double x;

      printf("Input eps:") ;

      scanf("%lf",&x); printf("\neps = %lf, PI=%lf\n", x, fun(x));

      NONO();

      }

       

      解題思路:

      本題是根據公式進行計算。

      參考答案:

      double fun ( double eps)

      {

      double s=1,t=1.0;

      int n=1;

      while(t>=eps)

      { s+=t; n++; t=t*n/(2.0*n+1); }

      return (s*2.0);

      }

      main( )

      { double x;

      printf("Input eps:") ;

      scanf("%lf",&x); printf("\neps = %lf, PI=%lf\n", x, fun(x));

      NONO();

      }

       

      ※※※※※※※※※※※※※※※※※※※※※※※※※

      28套:

       

       

      給定程序中,函數fun的功能是:統計形參s所指字符串中數字字符出現的次

      數,并存放在形參t所指的變量中,最后在主函數中輸出。例如,形參s所指的字

      符串為:abcdef35adgh3kjsdf7。輸出結果為:4。

      請在程序的下劃線處填入正確的內容并把下劃線刪除,使程序得出正確的結

      果。

      注意:源程序存放在考生文件夾下的BLANK1.C中。

      不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      void fun(char *s, int *t)

      { int i, n;

      n=0;

      /**********found**********/

      for(i=0; ___1___ !=NULL; i++)

      /**********found**********/

      if(s[i]>='0'&&s[i]<= ___2___ ) n++;

      /**********found**********/

      ___3___ ;

      }

      main()

      { char s[80]="abcdef35adgh3kjsdf7";

      int t;

      printf("\nThe original string is : %s\n",s);

      fun(s,&t);

      printf("\nThe result is : %d\n",t);

      }

      解題思路:

      第一處:在for循環中終止值要判斷字符串是否結束符,所以應填:s[i]。

      第二處:判斷是否是數字,所以應填:'9'。

      第三處:字符串中數字字符出現的次數n,并存放在形參t所指的變量中,所以應填:*t=n。

      ***************************************************

      給定程序MODI1.C中函數fun的功能是:通過某種方式實現兩個變量值的交換,

      規定不允許增加語句和表達式。例如變量a 中的值原為8,b中的值原為3, 程序運

      行后 a 中的值為 3,b中的值為8。

      請改正程序中的錯誤,使它能得出正確的結果。

      注意: 不要改動 main 函數,不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      int fun(int *x,int y)

      {

      int t ;

      /**************found**************/

      t = x ; x = y ;

      /**************found**************/

      return(y) ;

      }

      main()

       

       

      {

      int a = 3, b = 8 ;

      printf("%d %d\n", a, b) ;

      b = fun(&a, b) ;

      printf("%d %d\n", a, b) ;

      }

      解題思路:

      第一處:由于x是整型指針變量,所以地址不能賦值給整型變量,因此必須取x地址上的值,

      所以應改為t=*x;*x=y;。

      第二處:已交換后的值存放在t中,所以返回值應為return(t);。

      ***************************************************

      請編寫函數fun,它的功能是: 求出 1 1000 之間能被 7 11整除、但不

      能同時被 7 11 整除的所有整數并將它們放在a所指的數組中,通過 n 返回這

      些數的個數。

      注意: 部分源程序在文件PROG1.C中。

      請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括號中填入

      你編寫的若干語句。

      給定源程序:

      #include

      void fun (int *a, int *n)

      {

      }

      main( )

      { int aa[1000], n, k ;

      fun ( aa, &n ) ;

      for ( k = 0 ; k < n ; k++ )

      if((k + 1) % 10 == 0) printf("\n") ;

      else printf("]", aa[k]) ;

      NONO( );

      }

       

      解題思路:

      本題是利用for循環語句以及取模%運算來得出符合條件的整數并存入a所指的數組。

      參考答案:

      void fun (int *a, int *n)

      {

       

       

      int i ;

      *n = 0 ;

      for(i = 7 ; i < 1000 ; i++)

      if(((i % 7) == 0 || (i % 11) == 0) && (i % 77) != 0) a[(*n)++] = i ;

      }

       

      ※※※※※※※※※※※※※※※※※※※※※※※※※

      29套:

      程序通過定義學生結構體變量,存儲了學生的學號、姓名和3門課的成績。函

      fun的功能是對形參b所指結構體變量中的數據進行修改,最后在主函數中輸出修

      改后的數據。

      例如: b所指變量t中的學號、姓名、和三門課的成績依次是: 10002、

      "ZhangQi"、93、85、87,修改后輸出t中的數據應為:10004、" LiJie "、93、

      85、87。

      請在程序的下劃線處填入正確的內容并把下劃線刪除, 使程序得出正確的結

      果。

      注意:源程序存放在考生文件夾下的BLANK1.C中。

      不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      #include

      struct student {

      long sno;

      char name[10];

      float score[3];

      };

      void fun( struct student *b)

      { int i;

      /**********found**********/

       

       

      b__1__ = 10004;

      /**********found**********/

      strcpy(b__2__, "LiJie");

      }

      main()

      { struct student t={10002,"ZhangQi", 93, 85, 87};

      int i;

      printf("\n\nThe original data :\n");

      printf("\nNo: %ld Name: %s\nScores: ",t.sno, t.name);

      for (i=0; i<3; i++) printf("%6.2f ", t.score[i]);

      printf("\n");

      /**********found**********/

      fun(__3__);

      printf("\nThe data after modified :\n");

      printf("\nNo: %ld Name: %s\nScores: ",t.sno, t.name);

      for (i=0; i<3; i++) printf("%6.2f ", t.score[i]);

      printf("\n");

      }

      解題思路:

      本題是對結構體變量中的值進行修改并通過函數中的參數進行返回。

      第一處:對學號進行更改,所以應填:->no。

      第二處:對姓名進行更改,所以應填:->name。

      第三處:對函數的調用,所以應填:&t。

      ***************************************************

      給定程序MODI1.C中函數fun的功能是:應用遞歸算法求形參a的平方根。求平

      方根的迭代公式如下:

      1 a

      x1 = ( x0 + )

      2 x0

      例如,a2時,平方根值為:1.414214。

      請改正程序中的錯誤,使它能得出正確結果。

      注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構。

      給定源程序:

      #include

      #include

      /**********found**********/

      double fun(double a, dounle x0)

      { double x1, y;

      x1=(x0+ a/x0)/2.0;

      /**********found**********/

      if( fabs(x1-xo)>0.00001 )

      \TAB y=fun(a,x1);

      else y=x1;

      return y;

      }

      main( )

      { double x;

       

       

      printf("Enter x: "); scanf("%lf",&x);

      printf("The square root of %lf is %lf\n",x,fun(x,1.0));

      }

      解題思路:

      第一處: 第二個變量定義的保留字double寫錯。

      第二處: 變量x0錯寫成xo了。

      ***************************************************

      學生的記錄由學號和成績組成,N名學生的數據已在主函數中放入結構體數組

      s, 請編寫函數fun,它的功能是:把高于等于平均分的學生數據放在b所指的數

      組中,高于等于平均分的學生人數通過形參n傳回,平均分通過函數值返回。

      注意: 部分源程序在文件PROG1.C文件中。

      請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括號中填入

      你編寫的若干語句。

      給定源程序:

      #include

      #define N 12

      typedef struct

      { char num[10];

      double s;

      } STREC;

      double fun( STREC *a, STREC *b, int *n )

      {

      }

      main()

      { STREC s[N]={{"GA05",85},{"GA03",76},{"GA02",69},{"GA04",85},

      \TAB \TAB {"GA01",91},{"GA07",72},{"GA08",64},{"GA06",87},

      \TAB \TAB {"GA09",60},{"GA11",79},{"GA12",73},{"GA10",90}};

      STREC h[N], t;FILE *out ;

      int i,j,n; double ave;

      ave=fun( s,h,&n );

      printf("The %d student data which is higher than %7.3f:\n",n,ave);

      for(i=0;i

      printf("%s %4.1f\n",h[i].num,h[i].s);

      printf("\n");

      out = fopen("c:\\test\\out.dat","w") ;

      fprintf(out, "%d\n%7.3f\n", n, ave);

      for(i=0;i

      for(j=i+1;j

      if(h[i].s

      for(i=0;i

      fprintf(out,"%4.1f\n",h[i].s);

      fclose(out);

      }

      解題思路:

      本題是計算平均分并把高于平均分的記錄存入結構體數組中,最后平均分t通過函數值返

      回,人數n和符合條件的記錄b由形參傳回。

      1. 利用for循環計算平均分t。

       

       

      2. 利用for循環把高于平均分的學生記錄存入b中,人數*n1。

      參考答案:

      double fun( STREC *a, STREC *b, int *n )

      {

      double t=0 ;

      int i ;

      *n = 0 ;

      for(i = 0 ; i < N ; i++) t = t + a[i].s ;

      t = t / N ;

      for(i = 0 ; i < N ; i++) if(a[i].s > t) b[(*n)++] = a[i] ;

      return t ;

      }

       

      ※※※※※※※※※※※※※※※※※※※※※※※※※

      30套:

      程序通過定義學生結構體變量,存儲了學生的學號、姓名和3門課的成績。函

      fun的功能是將形參a所指結構體變量中的數據賦給函數中的結構體變量b,并修

      b中的學號和姓名,最后輸出修改后的數據。例如:a所指變量中的學號、姓名、

      和三門課的成績依次是:10001、"ZhangSan"、95、80、88,則修改后輸出b中的

      數據應為:10002、"LiSi"、95、80、88。

      請在程序的下劃線處填入正確的內容并把下劃線刪除, 使程序得出正確的結

      果。

       

       

       

       

      注意:源程序存放在考生文件夾下的BLANK1.C中。

      不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      #include

      struct student {

      long sno;

      char name[10];

      float score[3];

      };

      void fun(struct student a)

      { struct student b; int i;

      /**********found**********/

      b = __1__;

      b.sno = 10002;

      /**********found**********/

      strcpy(__2__, "LiSi");

      printf("\nThe data after modified :\n");

      printf("\nNo: %ld Name: %s\nScores: ",b.sno, b.name);

      /**********found**********/

      for (i=0; i<3; i++) printf("%6.2f ", b.__3__);

      printf("\n");

      }

      main()

      { struct student s={10001,"ZhangSan", 95, 80, 88};

      int i;

      printf("\n\nThe original data :\n");

      printf("\nNo: %ld Name: %s\nScores: ",s.sno, s.name);

      for (i=0; i<3; i++) printf("%6.2f ", s.score[i]);

      printf("\n");

      fun(s);

      }

      解題思路:

      本題是對結構體變量中的值進行修改。

      第一處:要修改的結構體變量是由形參a來傳遞的,所以應填:a。

      第二處:對結構體中的成員name進行替換,所以應填:b.name。

      第三處:分別輸出結構體中的成績,所以應填:score[i]。

      ***************************************************

      給定程序MODI1.C中函數fun的功能是:從s所指字符串中刪除所有小寫字母c。

      請改正程序中的錯誤,使它能計算出正確的結果。

      注意:不要改動 main 函數,不得增行或刪行,也不得更改程序的結構!

      給定源程序:

      #include

      void fun( char *s )

      { int i,j;

      for(i=j=0; s[i]!='\0'; i++)

      if(s[i]!='c')

       

       

      /************found************/

      \TAB s[j]=s[i];

      /************found************/

      s[i]='\0';

      }

      main()

      { char s[80];

      printf("Enter a string: "); gets(s);

      printf("The original string: "); puts(s);

      fun(s);

      printf("The string after deleted : "); puts(s);printf("\n\n");

      }

      解題思路:

      第一處: 新字符串的位置值是由變量j來控制的,但程序中字符賦值后沒有對j進行增量的

      語句,所以應改為:s[j++]=s[i];。

      第二處: 對新字符串添加字符串結束符,由于程序中使用變量j對新字符串來控制的,所以

      應改為:s[j]=0;。

      假定輸入的字符串中只包含字母和*號。請編寫函數fun,它的功能是:將字

      符串中的前導*號全部移到字符串的尾部。函數fun中給出的語句僅供參考。

      例如,字符串中的內容為:*******A*BC*DEF*G****,移動后,字符串中的內

      容應當是:A*BC*DEF*G***********。在編寫函數時, 不得使用C語言提供的字符

      串函數。

      注意: 部分源程序在文件PROG1.C文件中。

      請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括號中填入

      你編寫的若干語句。

      給定源程序:

      #include

      void fun( char *a )

      {

      /* 以下代碼僅供參考 */

      char *p,*q;

      int n=0;

      p=a;

      while(*p=='*') /* 統計串頭'*'個數n */

      {n++; p++;}

      q=a;

      /* 向前復制字符串,請填寫相應的語句完成其功能 */

      for(;n>0;n--) /* 在串尾補n'*' */

      *q++='*';

      *q='\0';

      }

      main()

      { char s[81],*p; int n=0;

      printf("Enter a string:\n");gets(s);

      fun( s );

      printf("The string after moveing:\n");puts(s);

      NONO();

       

       

      }

       

      解題思路:

      本題是考察字符串的移動。具體操作請看參考源程序。

      參考答案:

      void fun( char *a )

      {

      /* 以下代碼僅供參考 */

      char *p,*q;

      int n=0;

      p=a;

      while(*p=='*') /* 統計串頭'*'個數n */

      {n++; p++;}

      q=a;

      /* 向前復制字符串,請填寫相應的語句完成其功能 */

      while(*p) {

      *q=*p;

      p++;q++;

      }

      for(;n>0;n--) /* 在串尾補n'*' */

      *q++='*';

      *q='\0';

      }

       

       

      中文在线字幕第一页_中文字幕高跟丝袜作品番号_亚洲中文无无码第_日本亚洲欧美国产日韩a??y_在线观看亚洲av无码专区