计算机三级100上机题(4)

2019-04-08 21:14

薄观约取 厚积薄发 断点-影子

else if (isalpha(*s)) *s += 1; s++;} }

main( ) {

char a[N]; clrscr();

printf(\

printf(\chg(a);

printf(\puts (a);

readwriteDAT() ; }

void readwriteDAT() {

int i ; char a[N] ;

FILE *rf, *wf ;

rf = fopen(\wf = fopen(\for(i = 0 ; i < 50 ; i++) { fscanf(rf, \ chg(a) ;

fprintf(wf, \}

fclose(rf) ; fclose(wf) ; }

*****************************************************************************

★☆题目12(结构体运算题题)

已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:

按产品名称从小到大进行排列,若产品名称相等,则按金额从小到大进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT5.DAT中。

部分源程序存在文件prog1.c中。 请勿改动主函数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() {int i,j; PRO xy;

for(i=0;i<99;i++) for(j=i+1;j<100;j++)

if(strcmp(sell[i].mc,sell[j].mc)>0||strcmp(sell[i].mc,sell[j].mc)==0&&sell[i].je>sell[j].je)

{xy=sell[i];sell[i]=sell[j];sell[j]=xy;} }

void main() {

memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); }

void ReadDat() {

FILE *fp;

char str[80],ch[11]; int i;

fp=fopen(\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() {

FILE *fp; int i;

fp=fopen(\for(i=0;i<100;i++){

printf(\.sl,sell[i].je);

fprintf(fp,\

sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je); }

fclose(fp); }

**************************************************************************

题目13(结构体运算题)

已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能

要求:按产品代码从小到大进行排列,若产品代码相等,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT9.DAT中。

部分源程序存在文件prog1.c中。 请勿改动主函数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() {int i,j; PRO xy;

for(i=0;i<99;i++) for(j=i+1;j<100;j++)

if(strcmp(sell[i].dm,sell[j].dm)>0||strcmp(sell[i].dm,sell[j].dm)==0&&sell[i].je

{xy=sell[i];sell[i]=sell[j];sell[j]=xy;} }

void main() {

memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); }

void ReadDat() {

FILE *fp;

char str[80],ch[11]; int i;

fp=fopen(\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() {

FILE *fp; int i;

fp=fopen(\

断点亡魂

薄观约取 厚积薄发 断点-影子

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

printf(\

sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je); fprintf(fp,\

sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je); }

fclose(fp); }

**************************************************************************

★☆题目14(整数统计排序题)

已知数据文件IN.DAT中存有200个四位数,并已调用读函数readDat()把这些数存入数组a中,请考生编制一函数jsVal(),其功能是:依次从数组a中取出一个四位数,如果该四位数连续大于该四位数以后的五个数且该数是奇数(该四位数以后不满五个数,则不统计),则统计出满足此条件的个数cnt并把这些四位数按从小到大的顺序存入数组b中,最后调用写函数writeDat( )把结果cnt以及数组b中符合条件的四位数输出到OUT.DAT文件中。 注意:部分源程序存在文件prog1.c中。

程序中已定义数组:a[200],b[200],已定义变量:cnt 请勿改动数据文件IN.DAT中的任何数据、主函数main()、读函数readDat()和写函数writeDat()的内容。 #include #define MAX 200

int a[MAX], b[MAX], cnt = 0 ; void jsVal() {int i,j,flag;

for(i=0;i

if(a[i]>a[j]&&a[i]%2) flag=1; else {flag=0;break;}

if(flag==1) b[cnt++]=a[i]; }

for(i=0;i

for(j=i+1;j

if(b[i]>b[j]) {flag=b[i];b[i]=b[j];b[j]=flag;} }

void readDat() {

int i ; FILE *fp ;

fp = fopen(\

for(i = 0 ; i < MAX ; i++) fscanf(fp, \fclose(fp) ; }

断点亡魂


计算机三级100上机题(4).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:作文的题材和体裁

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: