C語言項(xiàng)目小學(xué)生數(shù)學(xué)考試系統(tǒng)參考
【項(xiàng)目3-小學(xué)生數(shù)學(xué)考試系統(tǒng)】
1.做一個(gè)小學(xué)生考試系統(tǒng),功能包括:
(1)利用隨機(jī)數(shù)出10道加法題;
(2)小學(xué)生用戶答題給出每道題的答案;
(3)對(duì)小學(xué)生的答題進(jìn)行評(píng)判;
(4)計(jì)算出小學(xué)生答題正確率。
2. 進(jìn)一步改進(jìn),提高題目質(zhì)量。
要求(1)百以內(nèi)算術(shù):運(yùn)算數(shù)、結(jié)果都在100以內(nèi)!
(2)先隨機(jī)產(chǎn)生運(yùn)算符后,針對(duì)各個(gè)運(yùn)算產(chǎn)生運(yùn)算數(shù)保證下列要求:對(duì)加法,兩數(shù)之和保證不大于100;對(duì)減法,被減數(shù)大于減數(shù),且被減數(shù)不大于100;對(duì)乘法:兩數(shù)之積不超過100;對(duì)除法:被除數(shù)大于除數(shù),且被除數(shù)不大于100,除數(shù)不許為0。
3. 建立一個(gè)文件,里面包含人工出好的題目。程序從文件中讀取題目。
參考解答:
1.做一個(gè)小學(xué)生考試系統(tǒng),功能包括:
(1)利用隨機(jī)數(shù)出10道加法題;
(2)小學(xué)生用戶答題給出每道題的答案;
(3)對(duì)小學(xué)生的答題進(jìn)行評(píng)判;
(4)計(jì)算出小學(xué)生答題正確率。
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main()
{
int sum=0;/*學(xué)生答對(duì)題目*/
int a,b,d,t; /*分別表示兩個(gè)運(yùn)算數(shù),正確答案及學(xué)生輸入的答案*/
int i;
srand(time(0)); /*初始化隨機(jī)種子*/
for(i=0; i<10; i++)
{
printf("第 %d 題: ", i+1);
a=rand()%10+1;
b=rand()%10+1;
d=a+b; /*得到正確答案*/
printf("%d+%d=", a, b);
scanf("%d", &t);
if(t==d) /*用戶輸入的答案與正確答案對(duì)比*/
{
printf(" right! \n");
sum++;
}
else
printf(" wrong! \n");
}
printf("共答對(duì)了%d道題,得分率%.2f\n", sum, 1.0*sum/10*100);
return 0;
}
進(jìn)一步改進(jìn),提高題目質(zhì)量。
要求(1)百以內(nèi)算術(shù):運(yùn)算數(shù)、結(jié)果都在100以內(nèi)!
(2)先隨機(jī)產(chǎn)生運(yùn)算符后,針對(duì)各個(gè)運(yùn)算產(chǎn)生運(yùn)算數(shù)保證下列要求:對(duì)加法,兩數(shù)之和保證不大于100;對(duì)減法,被減數(shù)大于減數(shù),且被減數(shù)不大于100;對(duì)乘法:兩數(shù)之積不超過100;對(duì)除法:被除數(shù)大于除數(shù),且被除數(shù)不大于100,除數(shù)不許為0。
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main()
{
int sum=0;//學(xué)生得分
int a,b,d,t; //分別表示兩個(gè)運(yùn)算數(shù),正確答案及學(xué)生輸入的答案
int c; //運(yùn)算:0-加 1-減 2-乘 3-除
int i;
srand(time(0)); //初始化隨機(jī)種子
for(i=0; i<10; i++)
{
printf("第 %d 題: ", i+1);
c=rand()%4;
do
{
a=rand()%100+1;
b=rand()%100+1;
if(a<b&&(c==1||c==3)) //給小學(xué)生的題,減和除運(yùn)算保證大減小和大除以小
{
d=a;
a=b;
b=d;
}
if(c==3)//對(duì)于除法,調(diào)整被除數(shù),以保證能整除
a=(a/b)*b;
}while((a+b)>=100||a*b>=100);
//以上滿足了題意的要求,但可以看到出題質(zhì)量還可以優(yōu)化
switch(c)
{
case 0://加法
d=a+b;
printf("%d+%d=", a, b);
break;
case 1: //減法
d=a-b;
printf("%d—%d=", a, b);
break;
case 2: //乘法
d=a*b;
printf("%d×%d=", a, b);
break;
case 3: //除法
d=a/b;
printf("%d÷%d=", a, b);
break;
}
scanf("%d", &t);
if(t==d)
{
printf(" right! \n");
sum++;
}
else
printf(" wrong! \n");
}
printf("共答對(duì)了%d道題,得分率%.2f\n", sum, 1.0*sum/10*100);
return 0;
}
3.建立一個(gè)文件,里面包含人工出好的題目。程序從文件中讀取題目。
#include <stdio.h>
#include <stdlib.h>
int main()
{
int sum=0;//學(xué)生得分
int a,b,d,t; //分別表示兩個(gè)運(yùn)算數(shù),正確答案及學(xué)生輸入的答案
char c; //運(yùn)算:0-加 1-減 2-乘 3-除
int i;
FILE *fp;
fp=fopen("excise.txt","r");
if(fp==NULL)
{
printf("cannot open file!\n");
exit(1);
}
for(i=0; i<10; i++)
{
fscanf(fp, "%d%c%d", &a, &c, &b);
printf("第 %d 題: ", i+1);
switch(c)
{
case '+'://加法
d=a+b;
printf("%d+%d=", a, b);
break;
case '-': //減法
d=a-b;
printf("%d—%d=", a, b);
break;
case '*': //乘法
d=a*b;
printf("%d×%d=", a, b);
break;
case '/': //除法
d=a/b;
printf("%d÷%d=", a, b);
break;
}
scanf("%d", &t);
if(t==d)
{
printf(" right! \n");
sum++;
}
else
printf(" wrong! \n");
}
printf("共答對(duì)了%d道題,得分率%.2f\n", sum, 1.0*sum/10*100);
fclose(fp);
return 0;
}
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
C語言數(shù)據(jù)結(jié)構(gòu)二叉樹之堆的實(shí)現(xiàn)和堆排序詳解
堆是計(jì)算機(jī)科學(xué)中一類特殊的數(shù)據(jù)結(jié)構(gòu)的統(tǒng)稱,通常是一個(gè)可以被看做一棵完全二叉樹的數(shù)組對(duì)象。而堆排序是利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計(jì)的一種排序算法。本文將詳細(xì)介紹堆的實(shí)現(xiàn)和堆排序,需要的可以參考一下2022-04-04
C++實(shí)現(xiàn)優(yōu)先隊(duì)列的示例詳解
普通的隊(duì)列是一種先進(jìn)先出的數(shù)據(jù)結(jié)構(gòu),元素在隊(duì)列尾追加,而從隊(duì)列頭刪除。在優(yōu)先隊(duì)列中,元素被賦予優(yōu)先級(jí)。本文將用C++實(shí)現(xiàn)優(yōu)先隊(duì)列,需要的可以參考一下2022-06-06
C++深入分析內(nèi)聯(lián)函數(shù)的使用
為了消除函數(shù)調(diào)用的時(shí)空開銷,C++ 提供一種提高效率的方法,即在編譯時(shí)將函數(shù)調(diào)用處用函數(shù)體替換,類似于C語言中的宏展開。這種在函數(shù)調(diào)用處直接嵌入函數(shù)體的函數(shù)稱為內(nèi)聯(lián)函數(shù)(Inline Function),又稱內(nèi)嵌函數(shù)或者內(nèi)置函數(shù)2022-04-04

