计算机三级网络技术2003年4月上机考试试题
部分源程序已给出。
请勿改动主函数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中。
酷影网(ky530.com)转载请注明出处,http://www.ky530.com/ncre/03/JiSuanJiSanJiWangLaoJiShu-2003-Nian-4-RuShangJiKaoShiShiDi.html
关键词: