最新三级数据库技术上机100套试题Word下载.docx
- 文档编号:19020922
- 上传时间:2023-01-03
- 格式:DOCX
- 页数:81
- 大小:47.40KB
最新三级数据库技术上机100套试题Word下载.docx
《最新三级数据库技术上机100套试题Word下载.docx》由会员分享,可在线阅读,更多相关《最新三级数据库技术上机100套试题Word下载.docx(81页珍藏版)》请在冰豆网上搜索。
60125099901270258088
处理后:
90126012702580885099
voidnumascend()
{inti,j,data;
for(i=0;
199;
for(j=i+1;
j<
200;
j++)
{if(original[i]%1000>
original[j]%1000)
{data=original[i];
original[i]=original[j];
original[j]=data;
}
elseif(original[i]%1000==original[j]%1000)
{if(original[i]<
original[j])
{data=original[i];
original[i]=original[j];
original[j]=data;
}
10;
result[i]=original[i];
3.已知文件IN.dat中存有100个产品销售记录,每个产品销售记录由产品代码code(字符型4位)、产品名称name(字符型10位)、单价uprice(整型)、数量amount(整型)、金额sum(长整型)5部分组成。
其中:
金额=单价×
数量。
函数RData()读取这100个销售记录并存入结构数组sell中。
请编写函数DescSort(),其功能要求:
按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WData(),把结果输出到文件OUT.dat中。
voidDescSort()
{inti,j;
PROtemp;
99;
100;
if(strcmp(sell[i].code,sell[j].code)<
0)
{temp=sell[i];
sell[i]=sell[j];
sell[j]=temp;
elseif(strcmp(sell[i].code,sell[j].code)==0)
{if(sell[i].sum<
sell[j].sum)
{temp=sell[i];
sell[i]=sell[j];
sell[j]=temp;
4.函数RData()实现从文件IN.dat中读取一篇英文文章,存入到字符串数组str中;
请编写encryptChar()函数,其功能是:
按给定的替代关系对数组str中的所有字符进行替代,仍存入数组str对应的位置上,最后调用函数WData(),把结果str输出到文件OUT.dat中。
替代关系:
f(p)=p*11mod256(p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果计算后f(p)值小于1等于32或大于130,则该字符不变,否则将f(p)所对应的字符进行替代。
原始数据文件存放的格式是:
每行的宽度均小于80个字符。
voidencryptChar()
{inti;
char*pf;
maxline;
{pf=str[i];
while(*pf!
=0)
{if(*pf*11%256<
=130&
&
*pf*11%256>
32)
*pf=*pf*11%256;
pf++;
5.函数RData()实现从文件IN.dat中读取一篇英文文章存入到字符串数组str中,请编写函数DescSort(),其功能是:
以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组str中,最后调用函数WData(),把结果str输出到文件OUT.dat中。
每行的宽度均小于80个字符(含标点符号和空格)。
例如,原文:
dAeBfC.
CcbbAA
结果:
fedCBA.
cbbCAA
voidDescSort(void)
{inti,j,k,strl;
charch;
{strl=strlen(str[i]);
for(j=0;
strl-1;
for(k=j+1;
k<
strl;
k++)
if(str[i][j]<
str[i][k])
{ch=str[i][j];
str[i][j]=str[i][k];
str[i][k]=ch;
6函数RData()实现从文件IN.dat中读取一篇英文文章存入字符串数组original中,请编写StrCharMove()函数,其功能是:
以行为单位把字符串中所有字符的ASCII值右移4位,然后把右移后的字符ASCII值再加上原字符的ASCII值,得到新的字符仍存入原字符串对应的位置上。
最后把已处理的字符串仍按行重新存入字符串数组original中。
最后调用函数WData(),把结果original输出到文件OUT.dat中。
voidStrCharMove(void)
{inti,j,strl;
{strl=strlen(original[i]);
original[i][j]+=original[i][j]>
>
4;
7.编写函数findStr(),其功能是:
统计一个长度为2的子字符串在另一个字符串中出现的次数。
例如,假定输入的字符串为"
asdasasdfgasdaszx67asdmklo"
,子字符串为"
as"
,函数返回值是6。
函数ReadWrite()实现从文件IN.dat中读取两个字符串,并调用函数findStr(),最后,把结果输出到文件OUT.dat中。
intfindStr(char*str,char*substr)
{intn;
char*p,*r;
n=0;
while(*str)
{p=str;
r=substr;
while(*r)
if(*r==*p)
{r++;
p++;
else
{break;
if(*r=='
\0'
)
str++;
returnn;
8.请编写函数CountValue(),它的功能是:
求n以内(不包括n),同时能被3与7整除的所有自然数之和的平方根s,并作为函数值返回。
主函数最后调用函数progReadWrite()从IN.dat文件中读取10组数据,分别得出结果,且把结果输出到文件OUT.dat中。
例如,若n为1000时,函数值应为:
s=153.909064。
doublecountValue(intn)
{doublexy=0.0;
inti;
for(i=1;
n;
if(i%3==0&
i%7==0)
xy+=i;
xy=sqrt((double)xy);
returnxy;
9已知在文件IN.dat中存有N个(N<
200)实数,函数RData()读取这N个实数并存入数组original中。
请编写函数CalValue(),要求实现的功能有:
①求出这N个实数的平均值(aver);
②分别求出这N个实数的整数部分之和(sumint)以及小数部分之和(sumdec),最后调用函数WData()把所求的结果输出到文件OUT.dat中。
voidCalValue(void)
doublex,sum=0;
MAXNUM;
{sumint=sumint+(int)original[i];
x=original[i]-(int)original[i];
sumdec=sumdec+x;
sum=sum+original[i];
aver=sum/MAXNUM;
10.已知数据文件IN.dat中存有300个四位数,并已调用读函数Rdata()把这些数存入数组a中,请编写函数primeNum(),其功能是:
求出所有这些四位数中素数的个数count,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从小到大的顺序进行排序。
最后调用写函数Wdata(),把结果输出到OUT.dat文件中。
例如,5591是素数,则该数满足条件存入数组b中,且个数count=count+1。
9812是非素数,则该数不满足条件,不存入数组b中,count值也不加1。
voidprimeNum()
{intj,i,value;
300;
if(isP(a[i]))
{b[count]=a[i];
count++;
count-1;
count;
if(b[i]>
b[j])
{value=b[i];
b[i]=b[j];
b[j]=value;
11.下列程序的功能是:
把s字符串中的所有字符左移一个位置,字符串中的第一个字符移到最后。
请编写函数change(char*s)实现程序要求,最后调用函数readwriteDAT()从IN.dat文件中读取50组数据,分别得出结果,且把结果输出到OUT.dat文件中。
例如,s字符串中原有内容为:
Mn.123xyZ,调用该函数后结果为:
n.123xyZM。
voidchange(char*s)
{inti,strl;
strl=strlen(s);
ch=*s;
*(s+i)=*(s+i+1);
*(s+strl-1)=ch;
12.下列程序的功能是:
找出所有100以内(含100)满足i、i+4、i+10都是素数的整数i(i+10也在100以内)的个数count以及这些i之和sum。
请编写函数primeNum()实现程序要求的功能,最后调用函数writeDat(),把结果count和sum输出到文件OUT.dat中。
for(i=2;
i<
=90;
i++)
if(isPrime(i)&
isPrime(i+4)&
isPrime(i+10))
{count++;
sum+=i;
容
13.函数Rdata()实现从文件IN.dat中读取一篇英文文章存入到字符串数组string中,请编写ConvertCharD()函数,其功能是:
以行为单位把字符串中的所有小写字母改写成该字母的上一个字母,如果是字母a,则改写成字母z。
大写字母仍为大写字母,小写字母仍为小写字母,其他字符不变,最后把已处理的字符串仍按行重新存入字符串数组string中。
最后调用函数Wdata(),把结果string输出到文件OUT.dat中。
Adb.Bcdza
abck.LLhj
Aca.Bbcyz
zabj.LLgi
voidConvertCharD(void)
{pf=string[i];
while(*pf)
{if(*pf=='
a'
*pf='
z'
;
elseif(*pf>
='
b'
&
*pf<
*pf-=1;
14.请编写函数countValue(),它的功能是:
求出1~1000之内能被7或11整除但不能同时被7或11整除的所有整数,将它们放在数组a中,并通过n返回这些数的个数。
主函数最后调用函数Wdata()把计算结果输出到OUT.dat中。
voidcountValue(int*a,int*n)
*n=0;
=1000;
if(i%7==0&
i%11)
{*a=i;
*n=*n+1;
a++;
elseif(i%7&
i%11==0)
15.已知数据文件IN.dat中存有300个四位数,并已调用读函数Rdata()把这些数存入数组a中,请编写函数primeCal(),其功能是:
求出这些四位数中素数的个数count,再求出所有满足此条件的四位数的平均值Ave1以及不满足此条件的四位数的平均值Ave2。
最后调用写函数Wdata(),把结果count、Ave1、Ave2输出到OUT.dat文件中。
例如,5591是素数,则该数满足条件计算平均值Ave1,且个数count=count+1。
9812是非素数,则该数不满足条件计算平均值Ave2。
voidprimeCal()
{Ave1+=a[i];
else
{Ave2+=a[i];
Ave1=Ave1/count;
Ave2=Ave2/(300-count);
16.下列程序的功能是:
寻找并输出11~999之间的数m,它满足m、m2和m3均为回文数。
所谓回文数是指各位数字左右对称的整数,例如121、676、94249等。
满足上述条件的数如m=11,m2=121,m3=1331皆为回文数。
请编写函数intpalindromevalue(longn)实现功能:
如果是回文数,则函数返回1,反之则返回0。
最后,把结果输出到文件OUT.dat中。
intpalindromevalue(longn)
{inti,strl,half;
chartemp[20];
ltoa(n,temp,10);
strl=strlen(temp);
half=strl/2;
half;
if(temp[i]!
=temp[--strl])
if(i>
=half)
return1;
else
return0;
17请补充程序,使得程序能实现以下功能:
从文件IN.dat中读取200个整数至数组number中,求出奇数的个数cnt1和偶数的个数cnt2以及数组number下标为偶数的元素值的算术平均值ave(保留2位小数)。
把结果cnt1、cnt2、ave输出到OUT.dat中。
for(i=0,j=0,cnt1=0,cnt2=0;
N;
{if(number[i]%2)
cnt1++;
cnt2++;
if(i%2==0)
j+=number[i];
ave=(float)j/(N/2);
18.函数Rdata()实现从文件IN.dat中读取一篇英文文章,存入到字符串数组string中,请编写函数CharRight(),其功能是:
以行为单位把字符串中的最后一个字符的ASCII值右移4位后加倒数第二个字符的ASCII值,得到最后一个新的字符;
倒数第二个字符的ASCII值右移4位后加倒数第三个字符的ASCII值,得到倒数第二个新的字符;
依此类推,一直处理到第二个字符;
第一个字符的ASCII值加原最后一个字符的ASCII值,得到第一个新的字符。
得到的新字符分别存放在原字符串对应的位置上,最后已处理的字符串仍按行重新存入字符串数组string中。
voidCharRight(void)
{strl=strlen(string[i]);
ch=string[i][strl-1];
for(j=strl-1;
j>
0;
j--)
{string[i][j]>
=4;
string[i][j]+=string[i][j-1];
string[i][0]+=ch;
19.已知数据文件IN.dat中存有200个四位数,并已调用读函数rdata()把这些数存入数组a中,请编写函数evenvalue(),其功能是:
如果四位数每位上的数字均是0、2、4、6或8,则统计出满足此条件的四位数的个数count,并把这些四位数按从大到小的顺序存入数组b中。
最后main()函数调用写函数wdata(),把结果count以及数组b中符合条件的四位数输出到OUT.dat文件中。
voidevenvalue()
{intbb[4];
inti,j,k,flag;
{bb[0]=a[i]/1000;
bb[1]=a[i]%1000/100;
bb[2]=a[i]%100/10;
bb[3]=a[i]%10;
{if(bb[j]%2==0)
{flag=1;
{flag=0;
if(flag==1)
if(b[i]<
{k=b[i];
b[j]=k;
20.函数RData()实现从文件IN.dat中读取一篇英文文章存入字符串数组StrResult中;
请编写Strmove()函数,其功能是:
以行为单位,依次把字符串中所有小写字母"
o"
左边的字符串内容移到该字符串的右边存放,然后把小写字母"
删除,余下的字符串内容移到已处理字符串的左边存放,之后把已处理的字符串仍按行重新存入字符串数组StrResult中。
最后main()函数调用函数WData(),把结果StrResult输出到文件OUT.dat中。
每行的宽度均小于80个字符,含标点符号和空格。
nanyfield.Yucancreateanindex
youhavethecorlrectrecord.
rd.yuhavethecrlrectrec
voidStrmove(void)
{inti,j,k;
charbuf[80];
{j=strlen(StrResult[i])-1;
while(StrResult[i][j]!
o'
=0)
j--;
if(j<
continue;
StrResult[i][j]=0;
strcpy(buf,&
StrResult[i][j+1]);
k=j=0;
while(StrResult[i][j])
{while(StrResult[i][j]!
StrResult[i][j])
j++;
if(!
StrResult[i][j])
{strcat(buf,&
StrResult[i][k]);
StrResult[i]
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 最新 三级 数据库技术 上机 100 试题