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

全國計算機等級考試南開C語言上機100題精簡版

5
下列程序的功能是:在三位整數(shù)(100至999)中尋找符合條件的整數(shù)并依次從小到大存入數(shù)組中;它既是完全平方數(shù),又是兩位數(shù)字相同,例如144、676等。請編制函數(shù)實現(xiàn)此功能,滿足該條件的整數(shù)的個數(shù)通過所編制的函數(shù)返回。最后調用函數(shù)writeDat()把結果輸出到文件out.dat中。請勿改動主函數(shù)main()和寫函數(shù)writeDat()的內容。
#include <stdio.h>

int jsvalue(int bb[])
{

}

main
{
int b[20],num;
num=jsvalue(b);
writeDat(num,b);
}

writeDat(int num,int b[])
{
FILE *out;
int i;

out=fopen(\"out.dat\",\"w\");
fprintf(out,\"%d\\n\",num);
for(i=0;i<num;i++)printf(out,\"%d\\n\",b[i]);
fclose(out);
}


--------------------------------------------------------------------------------

注:注意在i==(int)sqrt(i)*(int)sqrt(i)中只有當i是完全平方數(shù)時開平方后再取整才不會丟失任何數(shù)據(jù)。
int jsvalue(int bb[])
{
int i,j,k=0,g,s,b;
for(i=100;i<=999;i++)
{
g=i%10;
s=i/10%10;
b=i/100;
if((i==(int)sqrt(i)*(int)sqrt(i))&&(g==s//s==b//b==g))
bb[k++]=i;
}
return k;
}


int jsvalue(int bb[])
{
int i,k=0;
for(i=100;i<=999;i++)
if((int)sqrt(i)*(int)sqrt(i)==i && (i/100==i%10 || i/100==i/10%10 || i/10%10==i%10))
bb[k++]=i;
return k;

}


6
設有n個人圍坐一圈并按順時針方向從1到n編號, 從第s個人開始進行1到m的報數(shù), 報數(shù)到第m個人, 此人出圈, 再從他的下一個人重新開始1到m的報數(shù), 如此進行下去直到所有的人都出圈為止。
現(xiàn)要求按出圈次序, 每10人一組, 給出這n個人的順序表。請考生編制函數(shù)Josegh()實現(xiàn)此功能并調用函數(shù)WriteDat()把結果p輸出到文件JOSE.OUT中。
設 n = 100, s = 1, m = 10。
(1) 將1到n個人的序號存入一維數(shù)組p中;
(2) 若第i個人報數(shù)后出圈, 則將p[i]置于數(shù)組的倒數(shù)第i個位置上, 而原來第i+1個至倒數(shù)第i個元素依次向前移動一個位置;
(3) 重復第(2)步直至圈中只剩下p[1]為止。
注意: 部分源程序存放在PROG1.C中。
請勿改動主函數(shù)main()和輸出數(shù)據(jù)函數(shù)WriteDat()的內容。

初始化:
#include <stdio.h>
#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("%4d ", p[i]) ;
fprintf(fp, "%4d", 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 3 4 5 下一頁
文章搜索
版權聲明:如果計算機等級考試網(wǎng)所轉載內容不慎侵犯了您的權益,請與我們聯(lián)系800@exam8.com,我們將會及時處理。如轉載本計算機等級考試網(wǎng)內容,請注明出處。