首頁考試吧論壇Exam8視線考試商城網(wǎng)絡(luò)課程模擬考試考友錄實用文檔求職招聘論文下載
2013中考
法律碩士
2013高考
MBA考試
2013考研
MPA考試
在職研
中科院
考研培訓(xùn) 自學(xué)考試 成人高考
四 六 級
GRE考試
攻碩英語
零起點日語
職稱英語
口譯筆譯
申碩英語
零起點韓語
商務(wù)英語
日語等級
GMAT考試
公共英語
職稱日語
新概念英語
專四專八
博思考試
零起點英語
托?荚
托業(yè)考試
零起點法語
雅思考試
成人英語三級
零起點德語
等級考試
華為認(rèn)證
水平考試
Java認(rèn)證
職稱計算機 微軟認(rèn)證 思科認(rèn)證 Oracle認(rèn)證 Linux認(rèn)證
公 務(wù) 員
導(dǎo)游考試
物 流 師
出版資格
單 證 員
報 關(guān) 員
外 銷 員
價格鑒證
網(wǎng)絡(luò)編輯
駕 駛 員
報檢員
法律顧問
管理咨詢
企業(yè)培訓(xùn)
社會工作者
銀行從業(yè)
教師資格
營養(yǎng)師
保險從業(yè)
普 通 話
證券從業(yè)
跟 單 員
秘書資格
電子商務(wù)
期貨考試
國際商務(wù)
心理咨詢
營 銷 師
司法考試
國際貨運代理人
人力資源管理師
廣告師職業(yè)水平
衛(wèi)生資格 執(zhí)業(yè)醫(yī)師 執(zhí)業(yè)藥師 執(zhí)業(yè)護(hù)士
會計從業(yè)資格
基金從業(yè)資格
統(tǒng)計從業(yè)資格
經(jīng)濟(jì)師
精算師
統(tǒng)計師
會計職稱
法律顧問
ACCA考試
注冊會計師
資產(chǎn)評估師
審計師考試
高級會計師
注冊稅務(wù)師
國際內(nèi)審師
理財規(guī)劃師
美國注冊會計師
一級建造師
安全工程師
設(shè)備監(jiān)理師
公路監(jiān)理師
公路造價師
二級建造師
招標(biāo)師考試
物業(yè)管理師
電氣工程師
建筑師考試
造價工程師
注冊測繪師
質(zhì)量工程師
巖土工程師
造價員考試
注冊計量師
環(huán)保工程師
化工工程師
咨詢工程師
結(jié)構(gòu)工程師
城市規(guī)劃師
材料員考試
監(jiān)理工程師
房地產(chǎn)估價
土地估價師
安全評價師
房地產(chǎn)經(jīng)紀(jì)人
投資項目管理師
環(huán)境影響評價師
土地登記代理人
繽紛校園 實用文檔 英語學(xué)習(xí) 作文大全 求職招聘 論文下載 訪談|游戲
計算機等級考試
您現(xiàn)在的位置: 考試吧 > 計算機等級考試 > 計算機三級 > 三級數(shù)據(jù)庫 > 模擬試題 > 正文

2013年計算機三級數(shù)據(jù)庫上機模擬題及答案二

  設(shè)有n個人圍坐一圈并按順時針方向從1到n編號, 從第s個人開始進(jìn)行1到m的報數(shù), 報數(shù)到第m個人, 此人出圈, 再從他的下一個人重新開始1到m的報數(shù), 如此進(jìn)行下去直到所有的人都出圈為止。

  現(xiàn)要求按出圈次序, 每10人一組, 給出這n個人的順序表。請考生編制函數(shù)Josegh()實現(xiàn)此功能并調(diào)用函數(shù)WriteDat()把結(jié)果p輸出到文件JOSE.OUT中。

  設(shè) n = 100, s = 1, m = 10。

  (1) 將1到n個人的序號存入一維數(shù)組p中;

  (2) 若第i個人報數(shù)后出圈, 則將p[i]置于數(shù)組的倒數(shù)第i個位置上, 而原來第i+1個至倒數(shù)第i個元素依次向前移動一個位置;

  (3) 重復(fù)第(2)步直至圈中只剩下p[1]為止。

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

  請勿改動主函數(shù)main()和輸出數(shù)據(jù)函數(shù)WriteDat()的內(nèi)容。

  初始化:

  #include

  #define N 100

  #define S 1

  #define M 10

  int p[100], n, s, m ;

  void WriteDat(void) ;

  void Josegh(void)

  {

  }

  void main()

  {

  m = M ;

  n = N ;

  s = S ;

  Josegh() ;

  WriteDat() ;

  }

  void WriteDat(void)

  {

  int i ;

  FILE *fp ;

  fp = fopen("jose.out", "w") ;

  for(i = N - 1 ; i >= 0 ; i--) {

  printf("M ", p[i]) ;

  fprintf(fp, "M", p[i]) ;

  if(i % 10 == 0) {

  printf("\n") ;

  fprintf(fp, "\n") ;

  }

  }

  fclose(fp) ;

  }

  本題評析:

  參考答案及其注釋如下:

  void Josegh(void)

  {

  int i,j,s1,w;

  s1 = s;

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

  p[i-1] = i; /*初始化賦值*/

  for(i = n; i>=1; i--)

  {

  s1 = (s1 + m - 1)%i;

  if(s1 == 0)s1 = i;

  w = p[s1 - 1];

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

  p[j - 1] = p[j];

  p[i - 1] = w;

  }

  }

  s 開始 m 周期 n 總數(shù)

1 2  下一頁
文章搜索
計算機等級考試欄目導(dǎo)航
版權(quán)聲明:如果計算機等級考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請與我們聯(lián)系800@exam8.com,我們將會及時處理。如轉(zhuǎn)載本計算機等級考試網(wǎng)內(nèi)容,請注明出處。