亚洲国产福利在线一二三观看_精品国产伦一区二区三区欲臀_国产a∨视频精品视频护士_精品八戒人妻少妇av

江蘇省高校計算機等級考試命題研究院 江蘇省高校計算機等級考試輔導
2011年春江蘇計算機二級VC++上機真題1

   2011年春江蘇計算機 二級Visual C++上機試卷

    (本試卷完成時間為70分鐘)

  一、改錯題(20)

  【題目】

  以下程序的功能是:判斷一個已排序的整型數組中是否存在元素值與其下標值相等(下標從0開始)的元素。如果存在,則輸出其中一個該類元素的值(可能存在多個滿足條件的元素)

    正確程序的輸出如下:

    3個元素值與其下標值相等

    含有錯誤的源程序如下:

  #include <iostream.h>   

  int index_search(int x[n],int n)

  {

    int first=0;

    int last=n-1;

    int middle,index;

    index=-1;

    while(first<=last){

         middle=(first+last)/2;

         if(x[middle]=middle){

           index=middle;  

           break;

         }

         else if(x[middle]>middle)

            last=middle-1;

         else

            first=middle+1;

     }

      return index;

  }

  void main()

  {

    int a[]={-1,0,1,3,8};

    int result=index_search(a,sizeof(a));

    if(result==-1)

      cout<<""<<result<<"個元素值與其下標值相等"<<endl;

    else

      cout<<"不存在下標值等于元素值的元素"<<endl;

  }

    【要求】

    1.把上述程序錄入到文件myfa.cpp,根據題目要求及程序中語句之間的邏輯關系對程序中的錯誤進行修改。程序中的注解可以不輸入。

    2.改錯時,可以修改語句中的-部分內容,增加少量的變量說明、函數原型說明或編譯預處理命令,但不能增加其他語句,也不能刪除整條語句。

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

 二、編程題(20)

    【題目】

    試定義一個時間類time,具體要求如下:

    (1)私有數據成員。

    int h,m,s:分別表示時、分和秒。

    char *str_t:存放時間的字符串,格式為"hh:mm:ss","::"。

    (2)公有成員函數。

    time(int hh=0,int mm=0,int ss=0):構造函數,利用參數hh、mmss分別初始化成員hms,并為字符串str_t分配9個字節(jié)的動態(tài)存儲空間。要檢查參數hh、mmss的合法性,0hh<24,0mm<60,0ss<60,如果不合法,則采用相應的缺省參數值。

    ~time():析構函數,撤銷str_t所占用的動態(tài)存儲空間。

    void convert():利用全局函數itoa()將成員hms轉換為字符串"hh:mm:ss"的形式,并存儲在str_t中。

    void set_t(int hh,int mm,int ss):利用參數hh、mmss分別設置成員h、ms的值,同時調用成員函數convert()設置成員str_t。注意檢查參數的合法性。

    void print():輸出字符串str_t,按輸出示例中的格式輸出時間。

    (3)char *itoa(int n):全局函數,將整數n轉換為字符串形式并返回。只考慮n至多為兩位數的情形:n為一位數時,n=2,n轉換為"02"的形式;n為兩位數時,n=59,n轉換為"59"的形式。

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

    輸出示例:

    00:00:00

    12:05:30

    【要求】

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

    參考答案

  一、改錯題

    int index_search(int x[n],int n)    改為int x[]int *x

    if(x[middle]=middle){               改為x[middle]==middle

    int result=index_search(a,sizeof(a));    改為sizeof(a)/sizeof(int)5

    if(result==-1)            改為result!=-1result>=0result

 

二、編程題

    #inelude <iostream.h>

    #include <string.h>

    class time{

       int h,m,s;

       char *str_t;

    public:    -

       time(int hh=0,int mm=0,int ss=0)

        :h(hh>=0 && hh<24? hh:0),m(mm>=0 && mm<60? mm:0),s(ss>=0 &&ss<60?

          ss:0),str_t(new char[9])

       {    *str_t='\0';    }

       ~time()

      {delete []str_t;    }

      void set_t(int,int,int);

      void convert();

      void print() const

      {cout<<str_t<<endl;}

    };

    char *itoa(int n){

      char *tmp=new char[3];

      if(n<10){

       *tmp='0';

       *(tmp+1)=n+'0';

      }   

      else{

       *tmp=n/10+'0';

       *(tmp+1)=n%10+'0';

      }

      *(tmp+2)='\0';

      return tmp;

    }

    void time::set_t(int hh,int mm,int ss)

    {

     h=(hh>=0 && hh<24? hh:0),m=(mm>=0 && mm<60? mm:0),s=(ss>=0 && ss<

    60? ss:0);

     *str_t='\0':

     convert();

    }

    void time::convert()

    {

      char *tmp;

      tmp=itoa(h);

      strcat(str t,tmp);

      strcat(str_t,":");

      tmp=itoa(m);

      strcat(str_t,tmp);

      strcat(str_t,":");

      tmp=itoa(s);

      strcat(str_t,tmp);

      delete []tmp;

   }

   void main()

   {

    time t1;

    t1.convert();

    t1.print();

    t1.set_t(11,5,30);

    t1.print();

   }