| 网站首页 | 考研信息中心 | 考研资料下载 | 考研论坛 | 考研专业试题 | 2008考研招生简章 | 考研图书 | 留言板 | 考研图片中心 | 

设为首页
加入收藏
联系我们

您现在的位置: 考研信息网 >> 考研信息中心 >> 计算机类考试首页 >> Linux认证考试 >> 最新资讯 >> 正文 用户登录 新用户注册
全国计算机等级考试三级C语言上机题(41--50)          【字体:
全国计算机等级考试三级C语言上机题(41--50)
作者:佚名    文章来源:本站原创    点击数:    更新时间:2006-4-6

本站推荐Firefox浏览器,有效阻止病毒和垃圾弹出[正版免费下载]

☆题目41
下列程序prog1.c的功能是:计算出自然数SIX和NINE,它们满足的条件是SIX+SIX+SIX=NINE+NINE的个数cnt以及满足此条件所有的SIX与NINE的和SUM。请编写函数countValue()实现程序的要求,最后调用函数writeDat()把结果cnt和sum,输出到文件OUT15.DAT中。
 其中的S,I,X,N,E各代表一个十进制数字。
 部分源程序存在文件prog1.c中。
 请勿改动主函数main()和输出数据函数writeDat()的内容。
#include
int cnt,sum;

void countValue()
{ int s,i,x,n,e,six,nine;
 for(s=1;s<10;s++)
 for(i=0;i<10;i++)
 for(x=0;x<10;x++)
 for(n=1;n<10;n++)
 for(e=0;e<10;e++)
 { six=s*100+i*10+x;
 nine=n*1000+i*100+n*10+e;
 if(3*six==2*nine)
 { cnt++;sum+=six+nine;}
 }
}

void main()
{
 cnt=sum=0;

 countValue();
 printf("满足条件的个数=%d\n",cnt);
 printf("满足条件所有的SIX与NINE的和=%d\n",sum);
 writeDat();
}

writeDat()
{
 FILE *fp;

 fp=fopen("OUT15.DAT","w");
 fprintf(fp,"%d\n%d\n",cnt,sum);
 fclose(fp);
}

**************************************************************************
题目42
已知在文件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 {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("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()
{
 FILE *fp;
 int i;

 fp=fopen("OUT5.DAT","w");
 for(i=0;i<100;i++){
 printf("%s %s %4d %5d %5d\n",sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je);
 fprintf(fp,"%s %s %4d %5d %5d\n", sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je);
 }
 fclose(fp);
}

**************************************************************************
★题目43
无忧id 82题(只是将结果按“从大到小”排序)
函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(每行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串变量的下标为奇数的字符按其ASCII值从小到大的顺序进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数WriteDat()把结果xx输出到文件out.dat中。
  例如:位置   0 1 2 3 4 5 6 7 
     源字符串 a b c d e f g h
 则处理后字符串 a h c f e d g b
  部分源程序存在文件prog1.c中。
  请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
#include
#include
#include

char xx[20][80];

void jsSort()
{int i,j,k,strl;
 char ch;
 for(i=0;i<20;i++)
 { strl=strlen(xx[i]);
 for(j=1;j for(k=j+2;k if(xx[i][j]>xx[i][k]) { ch=xx[i][j];xx[i][j]=xx[i][k];xx[i][k]=ch;}
 }
}


void main()
{
 readDat();
 jsSort();
 writeDat();
}

readDat()
 {
 FILE *in;
 int i=0;
 char *p;

 in=fopen("in.dat","r");
 while(i<20&&fgets(xx[i],80,in)!=NULL){
 p=strchr(xx[i],'\n');
 if(p)*p=0;
 i++;
 }
 fclose(in);
 }

writeDat()
{
 FILE *out;
 int i;

 out=fopen("out.dat","w");
 clrscr();
 for(i=0;i<20;i++){
 printf("%s\n",xx[i]);
 fprintf(out,"%s\n",xx[i]);
 }
 fclose(out);
}

************************************************************************
★☆题目44
函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(每行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数WriteDat()把结果xx输出到文件out.dat中。
  条件:从字符串中间一分为二,左边部分按字符的ASCII值降序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加处理,字符仍放在原位置上。
  例如:位置   0 1 2 3 4 5 6 7 8
     源字符串 a b c d h g f e
 1 2 3 4 9 8 7 6 5
 则处理后字符串 h g f e d c b a
 8 7 6 5 9 4 3 2 1
  部分源程序存在文件prog1.c中。
  请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
#include
#include
#include

char xx[20][80];

void jsSort()
{ int i,j,k,strl,half;
 char temp;
 for(i=0;i<20;i++)
 { strl=strlen(xx[i]);
 half=strl/2;
 for(j=0;j for(k=j+1;k if(xx[i][j] { temp=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=temp;}
 for(j=half-1,k=strl-1;j>=0;j--,k--)
 { temp=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=temp;}
 }
}

void main()
{
 readDat();
 jsSort();
 writeDat();
}

readDat()
 {
 FILE *in;
 int i=0;
 char *p;

 in=fopen("in.dat","r");
 while(i<20&&fgets(xx[i],80,in)!=NULL){
 p=strchr(xx[i],'\n');
 if(p)*p=0;
 i++;
 }
 fclose(in);
 }

writeDat()
{
 FILE *out;
 int i;

 clrscr();
 out=fopen("out.dat","w");
 for(i=0;i<20;i++){
 printf("%s\n",xx[i]);
 fprintf(out,"%s\n",xx[i]);
 }
 fclose(out);
}


***********************************************************************
★题目45
已知数据文件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=5;i {for(j=i-5;j if(a[i]>a[j]&&a[i]%2==0) 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]}


void readDat()
{
 int i ;
 FILE *fp ;
 fp = fopen("in.dat", "r") ;
 for(i = 0 ; i < MAX ; i++) fscanf(fp, "%d", &a[i]) ;
 fclose(fp) ;
}

void main()
{
 int i ;
 readDat() ;
 jsVal() ;
 printf("满足条件的数=%d\n", cnt) ;
 for(i = 0 ; i < cnt ; i++) printf("%d ", b[i]) ;
 printf("\n") ;
 writeDat() ;
}

writeDat()
{
 FILE *fp ;
 int i ;
 fp = fopen("out.dat", "w") ;
 fprintf(fp, "%d\n", cnt) ;
 for(i = 0 ; i < cnt ; i++) fprintf(fp, "%d\n", b[i]) ;
 fclose(fp) ;
}

***********************************************************************
☆题目46
已知数据文件IN.DAT中存有200个四位数,并已调用读函数readDat()把这些数存入数组a中,请考生编制一函数jsVal(),其功能是:依次从数组a中取出一个四位数,如果该四位数连续大于该四位数以前的五个数且该数是奇数,且该数必须能被7整除(该四位数以前不满五个数,则不统计),则统计出满足此条件的个数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=5;i { for(j=i-5;j if(a[i]>a[j]&&a[i]%2&&a[i]%7==0) 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]}

void readDat()
{
 int i ;
 FILE *fp ;
 fp = fopen("in.dat", "r") ;
 for(i = 0 ; i < MAX ; i++) fscanf(fp, "%d", &a[i]) ;
 fclose(fp) ;
}

void main()
{
 int i ;
 readDat() ;
 jsVal() ;
 printf("满足条件的数=%d\n", cnt) ;
 for(i = 0 ; i < cnt ; i++) printf("%d ", b[i]) ;
 printf("\n") ;
 writeDat() ;
}

writeDat()
{
 FILE *fp ;
 int i ;
 fp = fopen("out.dat", "w") ;
 fprintf(fp, "%d\n", cnt) ;
 for(i = 0 ; i < cnt ; i++) fprintf(fp, "%d\n", b[i]) ;
 fclose(fp) ;
}

****************************************************************************
题目47
已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按金额从大到小进行排列,若金额相等,则按产品代码从小到大进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT3.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(sell[i].je0)
 {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("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()
{
 FILE *fp;
 int i;

 fp=fopen("OUT3.DAT","w");
 for(i=0;i<100;i++){
 printf("%s %s %4d %5d %5d\n", sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je);
 fprintf(fp,"%s %s %4d %5d %5d\n", sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je);
 }
 fclose(fp);
}


**************************************************************************
☆题目48
已知数据文件in.dat中存有300个四位数,并已调用读函数ReadDat()把这些数存入数组a中,请编制一函数jsValue(),其功能是:求出千位数上的数加个位数上的数等于百位数上的数加十位数上的数的个数cnt,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从小到大的顺序进行排序,最后调用写函数writeDat()把结果输出到out.dat文件。
 例如:6712,6+2=7+1,则该数满足条件存入数组b中,且个数cnt=cnt+1。
 8129,8+9<>1+2,则该数不满足条件忽略。
 部分源程序存在文件prog1.c中。
 程序中已定义数组:a[300],b[300],已定义变量:cnt
 请勿改动主函数main()、读函数ReadDat()和写函数writeDat()的内容。
#include
int a[300],b[300],cnt=0;

jsValue()
{int i,qw,bw,sw,gw,j;
 for(i=0;i<300;i++)
 {qw=a[i]/1000; bw=a[i]%1000/100;
 sw=a[i]%100/10; gw=a[i]%10;
 if(qw+gw==bw+sw) b[cnt++]=a[i];
 }
 for(i=0;i for(j=i+1;j if(b[i]>b[j]) {qw=b[i]; b[i]=b[j]; b[j]=qw;}
}


main()
{
 int i;

 readDat();
 jsValue();
 writeDat();
 printf("cnt=%d\n",cnt);
 for(i=0;i}

readDat()
{
 FILE *fp;
 int i;
 fp=fopen("in.dat","r");
 for(i=0;i<300;i++)fscanf(fp,"%d,",&a[i]);
 fclose(fp);
}

writeDat()
{
 FILE *fp;
 int i;
 fp=fopen("out.dat","w");
 fprintf(fp,"%d\n",cnt);
 for(i=0;i fclose(fp);
}


*****************************************************************************
题目49已知数据文件in.dat中存有300个四位数,并已调用读函数ReadDat()把这些数存入数组a中,请编制一函数jsValue(),其功能是:求出千位数上的数减百位数减十位数上的数减个位数上的数大于零的个数cnt,再求出所有满足此条件的四位数平均值pjz1,以及不满足此条件的四位数平均值pjz2,最后调用写函数writeDat()把结果输出到out.dat文件。
 例如:9123,9-1-2-3>0,则该数满足条件计算平均值pjz1,且个数cnt=cnt+1。9812,9-8-1-2<0,则该数不满足条件计算平均值pjz2。
 部分源程序存在文件prog1.c中。
 程序中已定义数组:a[300],已定义变量:cnt,pjz1,pjz2。
 请勿改动主函数main()、读函数ReadDat()和写函数writeDat()的内容。
#include
int a[300],cnt=0;
double pjz1=0.0,pjz2=0.0;

jsValue()
{int i,qw,bw,sw,gw,n=0;
 for(i=0;i<300;i++)
 {qw=a[i]/1000; bw=a[i]%1000/100;
 sw=a[i]%100/10; gw=a[i]%10;
 if(qw-bw-sw-gw>0) {cnt++;pjz1+=a[i];}
 else {n++;pjz2+=a[i];}
 }
 if(cnt==0) pjz1=0;
 else pjz1/=cnt;
 if(n==0) pjz2=0;
 else pjz2/=n;
}

main()
{
 int i;

 readDat();
 jsValue();
 writeDat();
 printf("cnt=%d\n满足条件的平均值pzj1=%7.2f\n不满足条件的平均值pzj2=%7.2f\n",cnt,pjz1,pjz2);
}

readDat()
{
 FILE *fp;
 int i;
 fp=fopen("in.dat","r");
 for(i=0;i<300;i++)fscanf(fp,"%d,",&a[i]);
 fclose(fp);
}

writeDat()
{
 FILE *fp;
 int i;
 fp=fopen("out.dat","w");
 fprintf(fp,"%d\n%7.2f\n%7.2f\n",cnt,pjz1,pjz2);
 fclose(fp);
}

*******************************************************************************
题目50
函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(每行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数WriteDat()把结果xx输出到文件out.dat中。
  条件:从字符串中间一分为二,左边部分按字符的ASCII值升序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加处理,字符仍放在原位置上。
  例如:位置   0 1 2 3 4 5 6 7 8
     源字符串 d c b a h g f e
 4 3 2 1 9 8 7 6 5
 则处理后字符串 h g f e a b c d
 8 7 6 5 9 1 2 3 4
  部分源程序存在文件prog1.c中。
  请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
#include
#include
#include

char xx[20][80];

void jsSort()
{ int i,j,k,strl,half;
 char temp;
 for(i=0;i<20;i++)
 { strl=strlen(xx[i]);
 half=strl/2;
 for(j=0;j for(k=j+1;k if(xx[i][j]>xx[i][k])
 { temp=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=temp;}
 for(j=half-1,k=strl-1;j>=0;j--,k--)
 { temp=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=temp;}
 }
}

void main()
{
 readDat();
 jsSort();
 writeDat();
}

readDat()
 {
 FILE *in;
 int i=0;
 char *p;

 in=fopen("in.dat","r");
 while(i<20 && fgets(xx[i],80,in)!=NULL){
 p=strchr(xx[i],'\n');
 if(p) *p=0;
 i++;
 }
 fclose(in);
 }

writeDat()
{
 FILE *out;
 int i;
 clrscr();
 out=fopen("out.dat","w");
 for(i=0;i<20;i++){
 printf("%s\n",xx[i]);
 fprintf(out,"%s\n",xx[i]);
 }
 fclose(out);
}

考研信息网在线版权与免责声明

1、 凡本站注明“稿件来源:考研信息网(sanwww.com)”的所有文字、图片和音视频稿件,版权均属本网所有,任何媒体、

网站或个人未经本网协议授权不得转载、转贴或以其他方式复制发表。已经本站协议授权的媒体、网站,在下载使用时

必须注明"稿件来源:sanwww.com",违者本站将依法追究责任。

2、本站注明稿件来源为其他媒体的文/图等稿件均为转载稿,本站转载出于非商业性的教育和科研之目的,并不意味着

赞同其观点或证实其内容的真实性。如转载稿涉及版权等问题,请作者在两周内速来电或来函联系。

3、考研试题、各种考试试题以及考试信息转载于各大bbs论坛,就其真实性本站无法证实,并不意味着赞同其观点。

如转载稿涉及版权等问题,请作者在两周内速来电或来函联系。

文章录入:san1    责任编辑:admin 
  • 上一篇文章:

  • 下一篇文章:
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
           最新热点        最新推荐        相关文章
    没有相关文章
    网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)