查看全部128种考试
计算机等级考试
 考试动态  报考指南  考试大纲  历年真题  模拟试题  复习资料  心得技巧 等考论坛
 二级 | VB  VF  C  C++  JAVA  ACCESS 三级 | 网络  数据库  信息管理  PC技术 四级 | 一级
1
2
3
4
5
6
7
8
9
10
萧雨  
【字体: 2003年4月全国计算机等级考试三级网络技术上机考试题
2003年4月全国计算机等级考试三级网络技术上机考试题
djks.exam8.com 来源:考试吧(Exam8.com) 更新:2004-8-11 23:40:00 计算机等级考试 考试论坛

    1.已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)四部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT10.DAT中。

部分源程序已给出。

请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。

#include

#include

#include

#include

#include


#define MAX 100

typedef struct{

char dm[5]; /*产品代码*/

char mc[11]; /*产品名称*/

int dj; /*单价*/

int sl; /*数量*/

long je; /*金额*/

}PRO;

PRO sell[MAX];

void ReadDat();

void WriteDat();


void SortDat()

{


}


void main()

{

memset(sell,0,sizeof(sell));

ReadDat();

SortDat();

WriteDat();

}


void ReadDat()

{

FILE *fp;

char str[80],ch[11];

int i;


fp=fopen("IN.DAT","r");

for(i=0;i<100;i++){

fgets(str,80,fp);

memcpy(sell[i].dm,str,4);

memcpy(sell[i].mc,str+4,10);

memcpy(ch,str+14,4);ch[4]=0;

sell[i].dj=atoi(ch);

memcpy(ch,str+18,5);ch[5]=0;

sell[i].sl=atoi(ch);

sell[i].je=(long)sell[i].dj*sell[i].sl;

}

fclose(fp);

}


void WriteDat(void)

{

FILE *fp;

int i;


fp=fopen("OUT10.DAT","w");

for(i=0;i<100;i++){

fprintf(fp,"%s %s %4d %5d %10Ld\n", sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je);

}

fclose(fp);

}"


--------------------------------------------------------------------------------


注:这时也是采用冒泡法进行排序。与前面的冒泡法在写法上有所不同请注意区分。

void SortDat()

{

int i,j;

PRO swap;

for(i=0;i for(j=0;j { if(strcmp(sell[j].dm,sell[j+1].dm)<0) /*用函数strcmp判断两个字符串的大小*/

{ swap=sell[j]; sell[j]=sell[j+1]; sell[j+1]=swap; }

if(strcmp(sell[j].dm,sell[j+1].dm)==0&&sell[j].je {

swap=sell[j];

sell[j]=sell[j+1];

sell[j+1]=swap;

}

}

}

若产品代码相同,则按金额从大到小进行排列没有体现!


2.six+six+six=nine+nine的个数cnt及它们的和sum,s,i,n,e是0-9自然数,但s,n不能为0.

如 984+984+984=1476+1476,

我临时编的(可能算法不太好)


main()

{

int i,j,cnt=0;

float sum=0;

for(i=100;i<1000;i++)

for(j=1000;j<10000;j++)

{

if(i+i+i==j+j)

{

cnt++;

sum=sum+i+j;

printf("%d+%d+%d=%d+%d\n",i,i,i,j,j);

}

}

printf("%d,%f",cnt,sum);

}


参考这个:for(i=666;i<1000;i++)

if((i/10%10=(3*i/2)/100%10)&&((i*3/2)/1000=(i*3/2)/10%10)

{cnt++;

sum+=(5/2)*i;

}

3.函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS4.DAT中。


替代关系:f(p)=p*11 mod 256 (p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果计算后f(p)值小于等于32或f(p)对应的字符是大写字母,则该字符不变,否则将f(p)所对应的字符进行替代。


部分源程序已给出。原始数据文件存放的格式是:每行的宽度均小于80个字符。


请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。


#include


#include


#include


#include

unsigned char xx[50][80];


int maxline=0;/*文章的总行数*/

int ReadDat(void)


void WriteDat(void)

void encryptChar()


{

}

void main()


{


clrscr();


if(ReadDat()){


printf(\"数据文件ENG.IN不能打开!\\n\\007\");


return;


}


encryptChar();


WriteDat();


}

int ReadDat(void)


{


FILE *fp;


int i=0;


unsigned char *p;

if((fp=fopen(\"eng.in\",\"r\"))==NULL) return 1;


while(fgets(xx[i],80,fp)!=NULL){


p=strchr(xx[i],'\\n');


if(p)*p=0;


i++;


}


maxline=i;


fclose(fp);


return 0;


}

void WriteDat(void)


{


FILE *fp;


int i;

fp=fopen(\"ps4.dat\",\"w\");


for(i=0;i printf(\"%s\\n\",xx[i]);


fprintf(fp,\"%s\\n\",xx[i]);


}


fclose(fp);


}

--------------------------------------------------------------------------------

注:下题1相似,只是它要求对f(p)进行判断。


void encryptchar()


{


int i;


char *pf;


for(i=0;i {pf=xx[i];


while(*pf!=0)


{if(*pf*11%256>='A'&&*pf*11%256<='Z'||*pf*11%256<32)


{pf++;continue;}


*pf=*pf*11%256;


pf++;


}


}


}


void encryptChar()


{


int i,j,t;


for(i=0;i {


for(j=0;j {


t=xx[i][j]*11%256;


if(t<=32 || t>='A' && t<='Z') continue;


xx[i][j]=t;


}


}


}


4.南开第一题

函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS10.DAT中。

替代关系:f(p)=p*11 mod 256 (p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果原字符的ASCII值是偶数或计算后f(p)值小于等于32,则该字符不变,否则将f(p)所对应的字符进行替代。

部分源程序已给出,原始数据文件存放的格式是:每行的宽度均小于80个字符。

请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。

#include

#include

#include

#include


unsigned char xx[50][80];

int maxline=0;/*文章的总行数*/


int ReadDat(void)

void WriteDat(void)


void encryptChar()

{


}


void main()

{

clrscr();

if(ReadDat()){

printf("数据文件ENG.IN不能打开!\n\007");

return;

}

encryptChar();

WriteDat();

}


int ReadDat(void)

{

FILE *fp;

int i=0;

unsigned char *p;


if((fp=fopen("eng.in","r"))==NULL) return 1;

while(fgets(xx[i],80,fp)!=NULL){

p=strchr(xx[i],'\n');

if(p)*p=0;

i++;

}

maxline=i;

fclose(fp);

return 0;

}


void WriteDat(void)

{

FILE *fp;

int i;

fp=fopen("ps10.dat","w");

for(i=0;i printf("%s\n",xx[i]);

fprintf(fp,"%s\n",xx[i]);

}

fclose(fp);

}


--------------------------------------------------------------------------------


注:在ReadDat()函数中由于fgets()函数读入数据时没有读入字符串结束符'\0',因

而用while()循环在xx数组每一行未尾将换行符'\n'替换成结束符'\0'。

编写的函数如下:该函数的基本算法是——让字符指针pf指向每一行的开头然后逐一往

后移动,在移动过程中按要求进行转换。*pf%2==0用于判断是否为偶数。if()条件语

句用于控制不替代字符。


解法1:


void encryptChar()

{

int i;

char *pf;

for(i=0;i {pf=xx[i]; /*每行字符个数*/

while(*pf!=0)

{if(*pf%2==0||*pf*11%256<32)

{pf++;continue;}

*pf=*pf*11%256;

pf++;

}

}


}


转帖于:计算机等级考试_考试吧
文章搜索  
看了本文的网友还看了:
计算机等级考试权威辅导教材: 订书电话:010-62168566  更多>>>
网友评论
昵 称: *  评 分: 1分 2分 3分 4分 5分
标题:   匿名发表    (共有条评论)查看全部评论>>
版权声明 -------------------------------------------------------------------------------------
  如果计算机等级考试网所转载内容不慎侵犯了您的权益,请与我们联系,我们将会及时处理。如转载本计算机等级考试网内容,请注明出处。
关于本站  网站声明  广告服务  联系方式  付款方式  站内导航  客服中心  友情链接  考试论坛  网站地图
Copyright © 2004-2008 考试吧计算机等级考试网 All Rights Reserved    
中国科学院研究生院权威支持(北京) 电 话:010-62168566 传 真:010-62192699
百度大联盟黄金认证  十佳网络教育机构  经营许可证号:京ICP060677