- 相關(guān)推薦
2017年計(jì)算機(jī)三級(jí)數(shù)據(jù)庫(kù)技術(shù)編程題及答案
編程題一直是計(jì)算機(jī)三級(jí)考生們頭疼的題目,為了幫助各位考生提高變成題做題能力,下面百分網(wǎng)小編為大家收集了以下編程題練習(xí),來(lái)看看吧!
1.已知數(shù)據(jù)文件in33.dat中存有300個(gè)4位數(shù),并已調(diào)用函數(shù)readDat()把這些數(shù)存入數(shù)組a中,請(qǐng)編制一函數(shù)jsValue(),其功能是:求出個(gè)位數(shù)上的數(shù)減千位數(shù)上的數(shù)減百位數(shù)上的數(shù)減十位數(shù)上的數(shù)大于0的個(gè)數(shù)cnt,再求出所有滿足此條件的4位數(shù)平均值pjz1,以及所有不滿足此條件的4位數(shù)平均值pjz2,最后調(diào)用函數(shù)writeDat()把結(jié)果cnt,pjz1,pjz2輸出到out33.dat文件。
例如:1239,9-1-2-3>0,則該數(shù)滿足條件,計(jì)算平均值pjz1,且個(gè)數(shù)cnt=cnt+1。
8129,9-8-1-2<0,則該數(shù)不滿足條件,計(jì)算平均值pjz2。
注意:部分源程序已給出。
程序中已定義數(shù)組:a[300],b[300],已定義變量:cnt,pjz1,pjz2。
請(qǐng)勿改動(dòng)主函數(shù)main()、讀函數(shù)readDat()和寫函數(shù)writeDat()的內(nèi)容。
#include
int a[300], cnt=0;
double pjz1=0.0,pjz2=0.0;
void readDat();
void writeDat();
void jsValue()
{
int i,thou,hun,ten,data,n=0;
for(i=0;i<300;i++)
{
thou=a[i]/1000; /*求四位數(shù)的千位數(shù)字*/
hun=a[i]%1000/100; /*求四位數(shù)的百位數(shù)字*/
ten=a[i]%100/10; /*求四位數(shù)的十位數(shù)字*/
data=a[i]%10; /*求四位數(shù)的個(gè)位數(shù)字*/
if(data-thou-hun-ten>0) /*如果個(gè)位數(shù)減千位數(shù)減百位數(shù)減十位數(shù)大于0*/
{
cnt++; /*統(tǒng)計(jì)滿足條件的數(shù)的個(gè)數(shù)*/
pjz1+=a[i]; /*將滿足條件的數(shù)求和*/
}
else
{
n++; /*否則統(tǒng)計(jì)不滿足條件的數(shù)的個(gè)數(shù)*/
pjz2+=a[i]; /*將不滿足條件的數(shù)求和*/
}
}
pjz1/=cnt; /*求滿足條件的數(shù)的平均值*/
pjz2/=n; /*求不滿足條件的數(shù)的平均值*/
}
void main()
{
readDat();
jsValue();
writeDat();
printf("cnt=%d\n滿足條件的平均值pjz1=%7.2lf\n不滿足條件的平均值pjz2=%7.2lf\n",cnt,pjz1,pjz2);
}
void readDat()
{
FILE *fp;
int i;
fp=fopen( "in33.dat","r");
for(i=0;i<300;i++)
fscanf(fp,"%d,",&a[i]);
fclose(fp);
}
void writeDat()
{
FILE *fp;
fp=fopen("out33.dat","w");
fprintf(fp,"%d\n%7.2lf\n%7.2lf\n",cnt ,pjz1,pjz2);
fclose(fp);
}
2.已知數(shù)據(jù)文件IN30.DAT中存有200個(gè)4位數(shù),并已調(diào)用讀函數(shù)readDat( )把這些數(shù)存入數(shù)組a中,請(qǐng)編制一函數(shù)jsVal( ),其功能是:把個(gè)位數(shù)字和千位數(shù)字重新組合成一個(gè)新的十位數(shù)ab(新十位數(shù)的十位數(shù)字是原4位數(shù)的個(gè)位數(shù)字,新十位數(shù)的個(gè)位數(shù)字是原4位數(shù)的千位數(shù)字),以及把百位數(shù)和十位數(shù)組成另一個(gè)新的十位數(shù)cd(新十位數(shù)的十位數(shù)字是原4位數(shù)的百位數(shù)字,新十位數(shù)的個(gè)位數(shù)字是原4位數(shù)的十位數(shù)字),如果新組成的兩個(gè)十位數(shù)必須是一個(gè)奇數(shù),另一個(gè)為偶數(shù)且兩個(gè)十位數(shù)中至少有一個(gè)數(shù)能被17整除,同時(shí)兩個(gè)新十位數(shù)字均不為0,則將滿足此條件的4位數(shù)按從大到小的順序存入數(shù)組b中,并要計(jì)算滿足上述條件的4位數(shù)的個(gè)數(shù)cnt,最后調(diào)用寫函數(shù)writeDat( )把結(jié)果cnt及數(shù)組b中符合條件的4位數(shù)輸出到OUT30.DAT文件中。
注意:部分源程序已給出。
程序中已定義數(shù)組:a[200],b[200],已定義變量:cnt。
請(qǐng)勿改動(dòng)主函數(shù)main()、讀函數(shù)readDat()和寫函數(shù)writeDat()的內(nèi)容。
#include
#define MAX 200
int a[MAX],b[MAX],cnt=0;
void writeDat();
void jsVal( )
{
int i,j; /*定義循環(huán)控制變量*/
int a1,a2,a3,a4; /*定義變量保存4位數(shù)的每位數(shù)字*/
int temp; /*定義數(shù)據(jù)交換時(shí)的暫存變量*/
int ab,cd; /*存儲(chǔ)重新組合成的十位數(shù)*/
for(i=0;i<200;i++) /*逐個(gè)取每一個(gè)4位數(shù)*/
{
a4=a[i]/1000; /*求4位數(shù)的千位數(shù)字*/
a3=a[i]%1000/100; /*求4位數(shù)的百位數(shù)字*/
a2=a[i]%100/10; /*求4位數(shù)的十位數(shù)字*/
a1=a[i]%10; /*求4位數(shù)的個(gè)位數(shù)字*/
ab=10*a1+a4; /*把個(gè)位數(shù)和千位數(shù)組合成一個(gè)新的十位數(shù)ab*/
cd=10*a3+a2; /*把百位數(shù)和十位數(shù)組成另一個(gè)新的十位數(shù)cd*/
if((ab%17==0||cd%17==0)&&((ab%2==0 && cd%2==1)||(ab%2==1 && cd%2==0)) && a1!=0 && a3!=0)
{ /*如果新組成的兩個(gè)十位數(shù)必須是一個(gè)奇數(shù),另一個(gè)為偶數(shù)且兩個(gè)十位數(shù)中至少有一個(gè)數(shù)能被17整除,同時(shí)兩個(gè)新十位數(shù)的十位上的數(shù)字均不為0*/
b[cnt]=a[i]; /*則將滿足條件的數(shù)存入數(shù)組b中*/
cnt++; /*統(tǒng)計(jì)滿足條件的數(shù)的個(gè)數(shù)*/
}
}
for(i=0;i
for(j=i+1;j
if(b[i]
{
temp=b[i];
b[i]=b[j];
b[j]=temp;
}
}
void readDat( )
{
int i;
FILE *fp;
fp=fopen("IN30.DAT","r");
for(i=0;i
fscanf(fp,"%d",&a[i]);
fclose(fp);
}
void main()
{
int i;
readDat();
jsVal();
printf("滿足條件的數(shù)=%d\n",cnt);
for(i=0;i
printf("%d ",b[i]);
printf("\n");
writeDat();
}
void writeDat()
{
FILE *fp;
int i;
fp=fopen("OUT30.DAT","w");
fprintf(fp,"%d\n",cnt);
for(i=0;i
fprintf(fp, "%d\n",b[i]);
fclose(fp);
}
【計(jì)算機(jī)三級(jí)數(shù)據(jù)庫(kù)技術(shù)編程題及答案】相關(guān)文章:
計(jì)算機(jī)三級(jí)《數(shù)據(jù)庫(kù)技術(shù)》訓(xùn)練題及答案10-27
計(jì)算機(jī)三級(jí)《數(shù)據(jù)庫(kù)技術(shù)》強(qiáng)化題及答案06-18
計(jì)算機(jī)三級(jí)數(shù)據(jù)庫(kù)技術(shù)沖刺題及答案05-22
計(jì)算機(jī)三級(jí)數(shù)據(jù)庫(kù)技術(shù)考前基礎(chǔ)題及答案08-31
計(jì)算機(jī)三級(jí)數(shù)據(jù)庫(kù)技術(shù)提分題及答案11-05
計(jì)算機(jī)三級(jí)數(shù)據(jù)庫(kù)技術(shù)臨考通關(guān)題及答案07-02
計(jì)算機(jī)三級(jí)《數(shù)據(jù)庫(kù)技術(shù)》強(qiáng)化訓(xùn)練題及答案07-12