首頁(yè) 考試吧論壇 Exam8視線 考試商城 網(wǎng)絡(luò)課程 模擬考試 考友錄 實(shí)用文檔 繽紛校園 英語(yǔ)學(xué)習(xí)
2010考研 | 自學(xué)考試 | 成人高考 | 專 升 本 | 法律碩士 | MBA/MPA | 中 科 院
四六級(jí) | 商務(wù)英語(yǔ) | 公共英語(yǔ) | 職稱日語(yǔ) | 職稱英語(yǔ) | 博思 | 口譯筆譯 | GRE GMAT | 日語(yǔ) | 托福
雅思 | 專四專八 | 新概念 | 自考英語(yǔ) | 零起點(diǎn)英、、、韓語(yǔ) | 在職申碩英語(yǔ)
在職攻碩英語(yǔ) | 成人英語(yǔ)三級(jí)
等級(jí)考試 | 水平考試 | 微軟認(rèn)證 | 思科認(rèn)證 | Oracle認(rèn)證 | Linux認(rèn)證
公務(wù)員 | 報(bào)關(guān)員 | 報(bào)檢員 | 外銷員 | 司法考試 | 導(dǎo)游考試 | 教師資格 | 國(guó)際商務(wù)師 | 跟單員
單證員 | 物流師 | 價(jià)格鑒證師 | 銀行從業(yè)資格 | 證券從業(yè)資格 | 人力資源管理師 | 管理咨詢師
期貨從業(yè)資格 | 社會(huì)工作者
會(huì)計(jì)職稱 | 注會(huì)CPA | 經(jīng)濟(jì)師 | 統(tǒng)計(jì)師 | 注冊(cè)稅務(wù)師 | 評(píng)估師 | 精算師 | 高會(huì) | ACCA | 審計(jì)師
法律顧問(wèn) | 會(huì)計(jì)證
一級(jí)建造師 | 二級(jí)建造師 | 造價(jià)師 | 監(jiān)理師 | 安全師 | 咨詢師 | 結(jié)構(gòu)師 | 建筑師 | 安全評(píng)價(jià)師
房地產(chǎn)估價(jià)師 | 土地估價(jià)師 | 設(shè)備監(jiān)理師 | 巖土工程師 | 質(zhì)量資格 | 房地產(chǎn)經(jīng)紀(jì)人 | 造價(jià)員
投資項(xiàng)目管理 | 土地代理人 | 環(huán)保師 | 環(huán)境影響評(píng)價(jià) | 物業(yè)管理師 | 城市規(guī)劃師 | 公路監(jiān)理師
公路造價(jià)工程師 | 招標(biāo)師
執(zhí)業(yè)護(hù)士 | 執(zhí)業(yè)醫(yī)師 | 執(zhí)業(yè)藥師 | 衛(wèi)生資格
您現(xiàn)在的位置: 考試吧(Exam8.com) > 軟件水平考試 > 歷年真題 > 程序員真題 > 正文

2003年程序員下午試題及答案

試題一(15分,每空3分)
  閱讀下列說(shuō)明和流程圖,將應(yīng)填入__(n)__的字句寫在答題紙的對(duì)應(yīng)欄內(nèi)。
  【流程圖說(shuō)明]
  下面的流程圖描述了對(duì)8位二進(jìn)制整數(shù)求補(bǔ)的算法。
  該算法的計(jì)算過(guò)程如下:從二進(jìn)制數(shù)的低位(最右位)開(kāi)始,依次向高位逐位查看,直到首次遇到“1”時(shí),停止查看。然后,對(duì)該“1”位左面的更高位(如果有的話),逐位求反,所得的結(jié)果就是對(duì)原二進(jìn)制數(shù)求補(bǔ)的結(jié)果。
  例如:對(duì)二進(jìn)制整數(shù)10101000求補(bǔ)的結(jié)果時(shí)01011000。
  設(shè)8位二進(jìn)制整數(shù)中的各位,從低位到高位,依次存放在整型數(shù)組BIT的BIT[1]~BIT[8]中。例如,二進(jìn)制整數(shù)10101000存放在數(shù)組BIT后,就有BIT[1]=0,BIT[2]=0,…,BIT[7]=0,BIT[8]=1。若流程圖中存在空操作,則用NOP表示。

  流程圖中__(1)__處按“循環(huán)變量名:循環(huán)初值,增量,循環(huán)終值”格式描述。

試題二(15分,每空3分)
  閱讀下列說(shuō)明和流程圖,將應(yīng)填入__(n)__的字句寫在答題紙的對(duì)應(yīng)欄內(nèi)。
  【函數(shù)說(shuō)明】
  函數(shù)sort(int a[],int n)的功能時(shí)對(duì)數(shù)組a中的a[0]~a[n-1]這n個(gè)元素進(jìn)行排序。排序過(guò)程如下:第一趟對(duì)所有的偶數(shù)下標(biāo)p,比較a和a[p+1],若a>a[p+1],則將兩者交換;第二趟對(duì)所有的奇數(shù)下標(biāo)q,比較a[q]和a[q+1],若a[q]>a[q+1],則將兩者交換;第三趟對(duì)偶數(shù)下標(biāo),第四趟對(duì)奇數(shù)下標(biāo),…,依次類推,直至整個(gè)數(shù)組元素有序排列為止。
  【函數(shù)]
  void sort (int a[],int n)
  {
    int I ,j,t,tag=1;
   for(j=0;j<n;j++=      {
    for (I=__(1)__;i<n-1;__(2)__=     {
         if (a>a[I+1])     {t=a;a=a[I+1];a[I+1]=t;tag=0;}
    }
    tag++
    if (__(3)__) break;
   }
  }
  對(duì)包含十個(gè)元素的數(shù)組a采用上述方法排序時(shí),元素間的比較次數(shù)最少為_(kāi)_(4)__次,最多為_(kāi)_(5)__次。

試題三(15分,每空3分)
  閱讀下列說(shuō)明和流程圖,將應(yīng)填入__(n)__的字句寫在答題紙的對(duì)應(yīng)欄內(nèi)。
  【函數(shù)說(shuō)明]
  函數(shù)movetoend(LinkedList La int i)的功能時(shí):將線性表示A的第I個(gè)元素移到表尾。若移動(dòng)成功,則返回0,否則返回-1。線性表A采用帶頭結(jié)點(diǎn)的單鏈表表示,La為表A的頭指針,如下圖所示。

  鏈表結(jié)點(diǎn)的類型定義為:
  typedef struct node {    
   int key;
   struct node *next;
  }*LinkedList
  【函數(shù)]
  int movetoend(LinkedList La,int i)
  {
   LinkedList p ,q,prep;
   Int k=1;
   P=La->next;prep=La;
   While(__(1)__){      /*查找第I個(gè)元素并使指針p指向該結(jié)點(diǎn)*/
    Prep=p; p=->next;k++
   }
   if (!p||k>i)return -1;
   if (__(2)__)        /*第I個(gè)元素結(jié)點(diǎn)已經(jīng)是表尾結(jié)點(diǎn),則無(wú)需移動(dòng)*/
   return 0;
   q=p;
   while(__(3)__)q=q-﹥next; /*查找表尾并使q指向表尾結(jié)點(diǎn)*/
   __(4)__=p->next;
   p->next=NULL;
   __(5)__;
   return 0;
  }

  從下列的2道試題(試題四至試題五)中任選1道解答。如果解答的試題數(shù)超過(guò)1道,則題號(hào)小的1道解答有效。

試題四(15分,每空3分)
  閱讀下列說(shuō)明和流程圖,將應(yīng)填入__(n)__的字句寫在答題紙的對(duì)應(yīng)欄內(nèi)。
  【說(shuō)明]
  某單位舉辦了一場(chǎng)知識(shí)競(jìng)賽,參加競(jìng)賽的選手為300名,依次從1~300進(jìn)行編號(hào)。競(jìng)賽時(shí)間為9:00~11:00。8道競(jìng)賽題目依次從‘A’~‘H’編號(hào),選手可按任意次序答題,每完成一道題目,可立即提交答案。若答題正確(Y),則選擇其他題目進(jìn)行解答,否則,可繼續(xù)做該題目或選擇其他題目進(jìn)行解答,直至競(jìng)賽結(jié)束。
  選手提交答案的情況及判定結(jié)果由專人即時(shí)錄入,錄入的數(shù)據(jù)如下表1所示,對(duì)競(jìng)賽情況進(jìn)行統(tǒng)計(jì)和排名的結(jié)果如表2所示。

表1:輸入數(shù)據(jù)

提交時(shí)間 選手編號(hào) 題目編號(hào) 是否正確
09:37 14 A N
09:50 8 A Y
09:51 9 B N
09:52 14 A N
10:14 5 A N
10:16 9 B N
10:23 5 A Y
10:23 8 B Y
10:27 14 A Y

表2:輸出結(jié)果

名次 選手編號(hào) 完成題目數(shù)量 總用時(shí)(分鐘)
1 8 2 133
2 5 1 103
3 14 1 127

  統(tǒng)計(jì)和排名的規(guī)則如下:
  1. 若選手X在競(jìng)賽時(shí)提交的題目P解答正確,2. 則解答該題目所用時(shí)間如下計(jì)算:
  解答題目P的用時(shí)=提交題目P正確的時(shí)間-競(jìng)賽的開(kāi)始時(shí)間+罰時(shí)
  罰時(shí)=提交題目P錯(cuò)誤解答的次數(shù)×20
  例如:表1中14號(hào)選手在10:27提交了題目A的正確解答,因此該選手正確解答該題目所用時(shí)間為87分鐘,由于之前的兩次提交錯(cuò)誤解答,罰時(shí)為2×20=40分鐘,所以14號(hào)選手解答題目A的用時(shí)=87+40=127(分鐘)。
  2.已經(jīng)提交正確答案的題目再次提交時(shí)不再計(jì)算。 
  3.競(jìng)賽結(jié)束時(shí),選手的總用時(shí)為所有解答正確的題目用時(shí)累加所得,解答不正確的題目不計(jì)時(shí)。 
  4.排名時(shí),完成題目數(shù)量多者排名靠前;若完成的題目數(shù)相同,則用時(shí)少者排名靠前;若完成的題目數(shù)和所用時(shí)間均相等,則名次相同;完成題目數(shù)為0的選手不參加排名。 
  函數(shù)void Statistic()的功能是:讀取輸入數(shù)據(jù),進(jìn)行統(tǒng)計(jì)、排名并輸出結(jié)果。
 。efine MAXN 300
  typedef struct {
   int no;          /*選手編號(hào)*/
   int num;        /*完成的題目數(shù)量*/
   int time;        /*完成題目的總用時(shí)*/
   int d[8];        /*d用于記錄提交第I個(gè)題目錯(cuò)誤答案的次數(shù)*/
   int a[8];        /*a用于記錄第I個(gè)題目是否已經(jīng)提交正確答案*/
  }Info;
 【函數(shù)】
  void Statistic () {
   char ch,pass;
   int I,j,k,h,m,t,time,MaxIndex;
   Info R[MAXN+1];
   For(I=1;I<=MAXN;I++){         /*數(shù)組R的元素置初值0*/
    R no=0; R num=0; R time=0;
    For(j=0;j<8;j++){R.d[j]=0;R.a[j]=0;}
   }/*for*/
   MaxIndex=0;
   While(1) {
    /*錄入一名選手提交答案的信息(小時(shí):分鐘,選手編號(hào),題目號(hào),是否正確)*/
    scanf(”%d:%d,%d,%c”,&h,&m,&k,&ch,&pass);
    if (h= =0) break;
    R[k] no=k;
    Time=__(1)__;
    If (isupper(ch))     ch=’a’+ch-‘A’;
    If (pass !=’Y’&& pass !=’Y’) { R[k] d[ch-‘a(chǎn)’]++;continue;}
    If (R[k] a[ch-‘a(chǎn)’]= =1) continue;
    R[k] a[ch-‘a(chǎn)’]=1;
    R[k] num++;
    R[k] time+=__(2)__;
    if (k>MaxIndex)  MaxIndex=k;
   }     /*while*/
   for (I=1;I<MaxIndex;I++) {  /*選擇排序*/
    for(t=I,j=I+1;j<=MaxIndex;j++)
    if (R[t] num<R[j] num || __(3)__ t=j;)
    if(__(4)__) { R[0]=R[t];R[t]=R;R=R[0];}
   }  /*for*/
   k=1;R[0]=R[1];
   for(I=1;I<=MaxIndex;I++)                 /*輸出排名情況*/
   if(R[i].num>0){ 
    if (R num!=R[0] num || R time!=R[0] time) k++;
    R[0]=__(5)__;
    Printf(“%d: %3d %4d %5d ”,k,R no,R num R time);
   } /*if*/
  } /*Statistic*/

 

轉(zhuǎn)帖于:軟件水平考試_考試吧
文章搜索
2003年程序員下午試題及答案網(wǎng)友評(píng)論網(wǎng)友評(píng)論
版權(quán)聲明 --------------------------------------------------------------------------------------
    如果軟件水平考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請(qǐng)與我們聯(lián)系,我們將會(huì)及時(shí)處理。如轉(zhuǎn)載本軟件水平考試網(wǎng)內(nèi)容,請(qǐng)注明出處。
 柳絮隨風(fēng)