試題7:
機試時間:2006年9月23日,下午4:30
考號:116
題目:南開59題
題目59函數(shù)jsVal(),其功能是:把千位數(shù)字和十位數(shù)字重新組成一個新的十位數(shù)ab(新十位數(shù)的十位數(shù)字是原四位數(shù)的千位數(shù)字,新十位數(shù)的個位數(shù)字是原四位數(shù)的十位數(shù)字),以及把個位數(shù)字和百位數(shù)字組成另一個新的十位數(shù)cd(新十位數(shù)的十位數(shù)字是原四位數(shù)的個位數(shù)字,新十位數(shù)的個位數(shù)字是原四位數(shù)的百位數(shù)字),如果新組成的兩個十位數(shù)ab<cd,ab必須是奇數(shù)且不能被5整除,cd必須是偶數(shù),同時兩個新數(shù)的十位數(shù)字均不為零,則將滿足此條件的四位數(shù)按從大到小的順序存入數(shù)組b中,并要計算滿足上述條件的四位數(shù)的個數(shù)cnt。
void jsVal()
{int i,thou,hun,ten,data,j;
int ab,cd;
for(i=0;i<MAX;i++)
{thou=a/1000; hun=a/100%10;
ten=a%100/10; data=a%10;
ab=10*thou+ten; cd=10*data+hun; if(((ab-cd)<0&&ab%2==1&&ab%5!=0)&&cd%2!=1&&ab>=10&&cd>=10)
{b[cnt]=a;cnt++;} }
for(i=0;i<cnt-1;i++)
for(j=i+1;j<cnt;j++)
if(b<b[j]) {data=b;b=b[j];b[j]=data;}}
(借用my0625的 )
試題8:
機試時間:9月23日
機試試題:如下
已知數(shù)據(jù)文件 IN.DAT 中存有 200 個四位數(shù),并已調(diào)用讀函數(shù) readDat() 把這些數(shù)存入數(shù)組 a 中,請考生編制一函數(shù) jsVal(),其功能是:把千位數(shù)字和十位數(shù)字重新組成一個新的含有兩位數(shù)字的數(shù) ab(新數(shù)的十位數(shù)字是原四位數(shù)的千位數(shù)字,新數(shù)的個位數(shù)字是原四位數(shù)的十位數(shù)字),以及把個位數(shù)字和百位數(shù)字組成另一個新的兩位數(shù)字 cd(新數(shù)的十位數(shù)字是原四位數(shù)的個位數(shù)字,新數(shù)的個位數(shù)字是原四位數(shù)的百位數(shù)字),如果新組成的兩個數(shù) ab-cd>=10 且 ab-cd<=20 且兩個數(shù)均是偶數(shù),同時兩個數(shù)的十位數(shù)字均不能為零,則將滿足此條件的四位數(shù)按從大到小的順序存入數(shù)組 b 中,并要計算滿足上述條件的四位數(shù)的個數(shù) cnt。最后 main() 函數(shù)調(diào)用寫函數(shù) writeDat() 把結果 cnt 以及數(shù)組b中符合條件的四位數(shù)輸出到OUT.DAT文件中。
---------
網(wǎng)友填寫的jsVal()函數(shù)程序代碼如下:
void jsVal()
{ int i,j,maxnum,ab,cd,thou,hun,ten,data;
for(i=0;i<MAX;i++)
{ thou=a/1000;
hun=a%1000/100;
ten=a%100/10;
data=a%10;
ab=thou*10+ten;
cd=data*10+hun;
if(ab-cd>=10&&ab-cd<=20&&ab%2==0&&cd%2==0&&thou!=0&&data!=0)
{ b[cnt]=a;cnt++;}
}
for(i=0;i<cnt-1;i++)
{ for(j=i+1;j<cnt;j+=1)
if(b<b[j])
{ maxnum=b[j];b[j]=b[ i ];b [ i ]=maxnum;}
}
}
試題9:
機試時間:9月23日17:10
機試試題:南開
下列程序的功能是找出所有100以內(nèi)(含100)滿足I,I+4,I+10都是素數(shù)的整數(shù)I(I+10也在100以內(nèi))的個數(shù)cnt以及這些I之和sum。請編寫函數(shù)countValue()實現(xiàn)程序要求的功能,最后調(diào)用函數(shù)writeDat()把結果cnt和sum輸出到文件out.dat中。
部分源程序存在文件prog1.c中。
請勿改動主函數(shù)main()和輸出數(shù)據(jù)函數(shù)writeDat()的內(nèi)容。
答案內(nèi)容:
void countValue()
{int i;
for(i=2;i<=90;i++)
if(isPrime(i)&&isPrime(i+4)&&isPrime(i+10))
{cnt++;sum+=i;}
}
isPrime函數(shù)已經(jīng)給定~~~~~