為幫助大家更好地備考計算機三級考試,掌握所學知識點。下面小編為大家分享了2017年計算機三級資料庫技術衝刺練習題,歡迎大家練習!
1.已知在檔案中存有若干個(<200)四位數字的正整數,函式RData()讀取這若干個正整數並存入陣列original中。請編寫函式CalValue(),其功能要求是:①求出這個檔案共有多少個正整數totNum;②求這些數右移1位後,產生的新數是偶數的數的個數toteven,以及滿足此條件的這些數(右移前的值)的算術平均值totavg。最後呼叫函式WData()把所求的結果輸出到檔案中。
【答案】
void CalValue(void)
{ int i, data;
for (i=0; i<maxnum; p="" i++)<="">
{ if (!original[i])
break;
if (original[i] > 0)
totNum++;
data = original[i]>>1;
if (data%2 == 0)
{ toteven++;
totavg += original[i];
}
}
totavg /= toteven;
}
2.已知資料檔案中存有200個四位數,並已呼叫讀函式RData()把這些數存入陣列a中,請編寫函式spellVal(),其功能是:把千位數字和十位數字重新組成一個新的二位數ab(新二位數的十位數字是原四位數的千位數字,新二位數的個位數字是原四位數的十位數字),以及把個位數字和百位數字組成另一個新的二位數cd(新二位數的十位數字是原四位數的個位數字,新二位數的個位數字是原四位數的`百位數字),如果新組成的兩個二位數ab-cd≥0且ab-cd≤10且兩個數均是奇數,同時兩個新數的十位數字均不為0,則將滿足此條件的四位數按從大到小的順序存入陣列b中,並要計算滿足上述條件的四位數的個數count。最後main()函式呼叫寫函式WData(),把結果count以及陣列b中符合條件的四位數輸出到檔案中。
【答案】
void spellVal()
{ int i, thou, hun, ten, data, j;
int ab, cd;
for (i=0; i<200; i++)
{ thou = a[i]/1000;
hun = a[i]00/100;
ten = a[i]0/10;
data = a[i];
if (thou==0 || data==0)
continue;
ab = 10*thou+ten;
cd = 10*data+hun;
if ((ab-cd)>=0 && (ab-cd)<=10 && ab%2==1 && cd%2==1)
{ b[cnt] = a[i];
cnt++;
}
}
for (i=0; i<cnt-1; p="" i++)<="">
for (j=i+1; j<cnt; p="" j++)<="">
if (b[i] < b[j])
{ data = b[i];
b[i] = b[j];
b[j] = data;
}
}
3.已知資料檔案中存有200個四位數,並已呼叫讀函式RData()把這些數存入陣列a中,請編寫函式seVal(),其功能是:依次從陣列a中取出一個四位數,如果該四位數連續小於該四位數以後的5個數且該數是偶數(該四位數以後不滿4個數,則不統計),則統計出滿足此條件的個數count並把這些四位數按從小到大的順序存入陣列b中。最後呼叫寫函式WData(),把結果count以及陣列b中符合條件的四位數輸出到檔案中。
注意:部分程式已經給出。程式中已定義陣列a[200]、b[200],已定義變數count。請勿改動資料檔案
【答案】
void seVal()
{ int i, j, flag = 0;
for (i=0; i<max-5; p="" i++)<="">
{ for (j=i+1; j<=i+5; j++)
if (a[i] < a[j])
{ flag = 1;
}
else
{ flag = 0;
break;
}
if (flag==1 && a[i]%2==0)
{ b[count] = a[i];
count++;
}
}
for (i=0; i<count-1; p="" i++)<="">
for (j=i+1; j<count; p="" j++)<="">
if (b[i] > b[j])
{ flag = b[i];
b[i] = b[j];
b[j] = flag;
}
}