2017年3月計算機三級網絡技術知識鞏固題
- 計算機三級
- 關注:2.97W次
想提高計算機等級考試成績平時就要多做練習,積累做題方法和技巧,提高做題速度。以下是小編為大家整理的2017年3月計算機三級網絡技術知識鞏固題,希望可以為您的學習帶來幫助!
1.已知數據文件中存有300個4位數,並已調用函數readDat()把這些數存入數組a中,請編制一函數jsValue(),其功能是:求出個位數上的數減千位數上的數減百位數上的數減十位數上的數大於0的個數cnt,再求出所有滿足此條件的4位數平均值pjz1,以及所有不滿足此條件的4位數平均值pjz2,最後調用函數writeDat()把結果cnt,pjz1,pjz2輸出到文件。
例如:1239,9-1-2-3>0,則該數滿足條件,計算平均值pjz1,且個數cnt=cnt+1。
8129,9-8-1-2<0,則該數不滿足條件,計算平均值pjz2。
注意:部分源程序已給出。
程序中已定義數組:a[300],b[300],已定義變量:cnt,pjz1,pjz2。
請勿改動主函數main()、讀函數readDat()和寫函數writeDat()的內容。
#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; /*求四位數的千位數字*/
hun=a[i]00/100; /*求四位數的百位數字*/
ten=a[i]0/10; /*求四位數的'十位數字*/
data=a[i]; /*求四位數的個位數字*/
if(data-thou-hun-ten>0) /*如果個位數減千位數減百位數減十位數大於0*/
{
cnt++; /*統計滿足條件的數的個數*/
pjz1+=a[i]; /*將滿足條件的數求和*/
}
else
{
n++; /*否則統計不滿足條件的數的個數*/
pjz2+=a[i]; /*將不滿足條件的數求和*/
}
}
pjz1/=cnt; /*求滿足條件的數的平均值*/
pjz2/=n; /*求不滿足條件的數的平均值*/
}
void main()
{
readDat();
jsValue();
writeDat();
printf("cnt=%dn滿足條件的平均值pjz1=%7.2lfn不滿足條件的平均值pjz2=%7.2lfn",cnt,pjz1,pjz2);
}
void readDat()
{
FILE *fp;
int i;
fp=fopen( "","r");
for(i=0;i<300;i++)
fscanf(fp,"%d,",&a[i]);
fclose(fp);
}
void writeDat()
{
FILE *fp;
fp=fopen("","w");
fprintf(fp,"%dn%7.2lfn%7.2lfn",cnt ,pjz1,pjz2);
fclose(fp);
}
2.已知數據文件中存有200個4位數,並已調用讀函數readDat( )把這些數存入數組a中,請編制一函數jsVal( ),其功能是:把個位數字和千位數字重新組合成一個新的十位數ab(新十位數的十位數字是原4位數的個位數字,新十位數的個位數字是原4位數的千位數字),以及把百位數字和十位數字組成另一個新的十位數cd(新十位數的十位數字是原4位數的百位數字,新十位數的個位數字是原4位數的十位數字),如果新組成的兩個數均為偶數且兩個十位數中至少有一個數能被9整除,同時兩個新十位數字均不為零,則將滿足此條件的4位數按從大到小的順序存入數組b中,並計算滿足上述條件的4位數的個數cnt,最後調用寫函數writeDat( )把結果cnt及數組b中符合條件的4位數輸出到文件中。
注意:部分源程序已給出。
程序中已定義數組:a[200],b[200],已定義變量:cnt。
請勿改動主函數main()、讀函數readDat()和寫函數writeDat()的內容。
#include
#define MAX 200
int a[MAX],b[MAX],cnt=0;
void writeDat();
void jsVal( )
{
int i,j; /*定義循環控制變量*/
int a1,a2,a3,a4; /*定義變量保存4位數的每位數字*/
int temp; /*定義數據交換時的暫存變量*/
int ab,cd; /*存儲重新組合成的十位數*/
for(i=0;i<200;i++) /*逐個取每一個4位數*/
{
a4=a[i]/1000; /*求4位數的千位數字*/
a3=a[i]%1000/100; /*求4位數的百位數字*/
a2=a[i]%100/10; /*求4位數的十位數字*/
a1=a[i]%10; /*求4位數的個位數字*/
ab=10*a1+a4; /*把個位數和千位數重新組合成一個新的十位數ab*/
cd=10*a3+a2; /*把百位數和十位數組成另一個新的十位數cd*/
if((ab%9==0||cd%9==0)&&(ab%2!=1)&&(cd%2!=1)&&a1!=0&&a3!=0)
/*如果新組成的兩個數均為偶數且兩個十位數中至少有一個數能被9整除,同時兩個新十位的十位上的數字均不為零*/
{
b[cnt]=a[i]; /*將滿足條件的4位數存入數組b中*/
cnt++; /*統計滿足條件的數的個數*/
}
}
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("","r");
for(i=0;i
fscanf(fp,"%d",&a[i]);
fclose(fp);
}
void main()
{
int i;
readDat();
jsVal();
printf("滿足條件的數=%dn",cnt);
for(i=0;i
printf("%dn",b[i]);
printf("n");
writeDat();
}
void writeDat()
{
FILE *fp;
int i;
fp=fopen("","w");
fprintf(fp,"%dn",cnt);
for(i=0;i
fprintf(fp, "%dn",b[i]);
fclose(fp);
}
- 文章版權屬於文章作者所有,轉載請註明 https://xuezhezhai.com/zh-mo/jsj/sanji/o9loze.html