<samp id="uu9tx"></samp>
        <samp id="uu9tx"><tr id="uu9tx"><nav id="uu9tx"></nav></tr></samp>
        <delect id="uu9tx"><legend id="uu9tx"><meter id="uu9tx"></meter></legend></delect>
                <samp id="uu9tx"><tr id="uu9tx"><meter id="uu9tx"></meter></tr></samp><nav id="uu9tx"></nav>
                <samp id="uu9tx"></samp>
                  <samp id="uu9tx"><tr id="uu9tx"><meter id="uu9tx"></meter></tr></samp>
                  江蘇省高校計算機等級考試命題研究院 江蘇省高校計算機等級考試輔導
                  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();

                  }

                   

                  亚洲欧美日韩国产一区二区三区_全亚洲免费一级黄片_国产一区二区三区不卡视频手机版_国产污三级网站在线观看