1. <small id="kntrr"><delect id="kntrr"></delect></small>
    2. <sub id="kntrr"></sub>
        1. <form id="kntrr"><listing id="kntrr"></listing></form>
            江蘇省高校計算機等級考試命題研究院 江蘇省高校計算機等級考試輔導
            2012秋江蘇計算機二級C++上機試卷第1套

            2012秋江蘇省高校計算機等級考試

            二級  C++上機試卷

            一、改錯題(20)

              【題目】

              以下程序的功能是:將一個整數轉換成相應的字符串,例如,將整數1024轉換成字符串1024”,將負整數-512轉換成字符串-512”

              正確程序的輸入/輸出結果如下(下劃線部分為鍵盤輸入)

              請輸入一個整數:123

               123

            請輸入一個負整數:-123

              -123

            含有錯誤的源程序如下:

            #include <iostream.h>

            #include <math.h>

             

            #define N 20;

            char *itoa(int x, char s[])  //將整數x轉換為字符串形式,結果存入數組s

            {

              int i=0,j=0;

              char c,tmp;

              if(x<0){

                 s[0]=’-‘;

                   i=j=1;

                  x=x*(-1);

              }

              if(x==0){

                s[0]=”0”;

                  s[1]='\0';

              }

              else{

                while(x)

                 {

                  c=x%10;

                    x/=10;

                   s[i++]=c;

                 }

                 s[i+1]='\0';

                 for(int k=j;k<(j+i)/2;k++) //交換數組s中數字的先后順序

                        tmp=s[k],s[k]=s[i+j-k-1],s[i+j-k-1]=tmp;

              }

              return s;

             

            }

             

            void main()

            {

              int x;

              char s[N];

              cout<<"請輸入一個整數";

              cin>>x;

              cout<<itoa(x,s)<<endl;

            }

              【要求】

                1.打開T盤中myfa.txt文件,將其文本拷貝到文件myfa.cpp(或將上述程序錄入到文

              myfa.cpp),根據題目要求及程序中語句之間的邏輯關系對程序中的錯誤進行修改。程

              序中的注解可以不輸入。 

                2.改錯時,可以修改語句中的一部分內容,增加少量的變量說明、函數原型說明或編譯預

                  處理命令,但不能增加其他語句,也不能刪除整條語句。

                3.將改正后的源程序文件myfa.cpp必須放在T盤根目錄下,供閱卷用。

             

            二、編程題(20)

            【題目】

             試定義一個類Array,實現由一個數組派生出另一個數組,派生規則如下:新數組的元素取值為原數組中相同位置元素的左、右兩個相鄰元素前后拼接后形成的整數(左鄰元素在前,右臨元素在后)。規定最左()列元素的左()臨元素為該元素所在行的最右()側的元素,具體要求如下:

             (1)私有數據成員

                 int  a[3][4]:原數組

                 int  b[3][4]:派生數組

            (2)公有成員函數

              Array(int t[][4],int n):構造函數,利用參數t的前n行元素初始化數據成員a

              int nn(int t1,int t2):返回t1、t2拼接后形成的整數(t1在前,t2在后)

              void fun() :按題意生成新數組,并將結果存放到數據成員b

              void print():按矩陣形式輸出成員數組

            (3)在主函數中對該類進行測試

              輸出示例:

              原數組:

              41  67  34   0

              69  24  78   58

              62  64  5    45

            派生數組

              67   4134   670  3441

            5824   6978   2458  7869

            4564   625    6445  562

             

            【要求】

              源程序文件名必須為myfb.cpp,并放在T盤根目錄下,供閱卷用

             

            一、改錯題

              #define N 20;             修改為#define N 20\

              s[0]=”0”;                修改為    s[0]=’0’;

              c=x%10;                修改為     c=x%10+’0’;

              s[i+1]='\0';              修改為           s[i]='\0';

             

            二、編程題

            #include <iostream.h>

            #include <stdlib.h>

            class Array{

               int a[3][4],b[3][4];

            public:

                 Array(int t[][4],int n)

                 {

                        for(int i=0;i<n;i++)

                               for(int j=0;j<4;j++)

                                      a[i][j]=t[i][j];

                 }

                 int nn(int t1,int t2)

                 {

                   if(t2==0)

                           return t1*10;

                    int n=1,t=t2;

                    while(t){

                     n=n*10;

                         t=t/10;

                    }

                    return t1*n+t2;

                 }

             

                 void fun()

                 {for(int i=0;i<3;i++)

                 for (int j=0;j<4;j++){

                   int u=j-1,d=j+1;

                    u=u<0?3:u;

                    d=d>3?0:d;

                    b[i][j]=nn(a[i][u],a[i][d]);

                 }

                 }

                 void print()

                 {

                        cout<<"原有數組"<<endl;

                        for(int i=0;i<3;i++)

                       for (int j=0;j<4;j++)

                                 cout<<a[i][j]<<'\t';

                          cout<<endl;

                          cout<<"派生數組"<<endl;

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

                       for (int j=0;j<4;j++)

                                 cout<<b[i][j]<<'\t';

             

                 }

             

            };

             

            void main()

            {

              int t[3][4];

              for(int i=0;i<3;i++)

                   for (int j=0;j<4;j++)

                      t[i][j]=rand()%100;

              Array test(t,4);

              test.fun();

              test.print();

            }

             

            国产在线精品一区二区三区不卡_亚洲第一极品精品无码_永久免费无码网站在线观看_亚洲av综合日韩