薄观约取 厚积薄发 断点-影子
strcpy(xx[i],str); }
}
void main() {
clrscr();
if(ReadDat()){
printf(\数据文件IN.DAT不能打开!\\n\\007\return; }
StrOL(); WriteDat(); }
int ReadDat(void) {
FILE *fp; int i=0; char *p;
if((fp=fopen(\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; clrscr();
fp=fopen(\for(i=0;i fprintf(fp,\} fclose(fp); } ******************************************************************************* ☆题目5(整数排序题) 在文件in.dat中有200个正整数,且每个数均在1000至9999之间。函数ReadDat()读取这200个数存放到数组aa中。请编制函数jsSort(),其函数的 断点亡魂 薄观约取 厚积薄发 断点-影子 功能是:要求按每个数的后三位的大小进行升序排列,然后取出满足此条件的前10个数依次存入数组bb中,如果后三位的数值相等,则按原先的数值进行降序排列。最后调用函数WriteDat()把结果bb输出到文件out.dat中。 例:处理前 6012 5099 9012 7025 8088 处理后 9012 6012 7025 8088 5099 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include int i,j,data; for(i=0;i<199;i++) for(j=i+1;j<200;j++) if(aa[i]00>aa[j]00||aa[i]00==aa[j]00&&aa[i] void main() { readDat(); jsSort(); writeDat(); } readDat() { FILE *in; int i; in=fopen(\ for(i=0; i<200; i++) fscanf(in,\fclose(in); } writeDat() { FILE *out; int i; clrscr(); out=fopen(\for(i=0; i<10; i++){ printf(\ fprintf(out,\ 断点亡魂 薄观约取 厚积薄发 断点-影子 } fclose(out); ☆题目6 正整数排序 在文件in.dat中有200个正整数,且每个数均在1000至9999之间。函数ReadDat()读取这200个数存放到数组aa中。请编制函数jsSort(),其函数的功能是:要求按每个数的后三位的大小进行降序排列,然后取出满足此条件的前10个数依次存入数组b中,如果后三位的数值相等,则按原先的数值进行升序排列。最后调用函数WriteDat()把结果bb输出到文件out.dat中。 例:处理前 9012 5099 6012 7025 8088 处理后 5099 8088 7025 6012 9012 注意:部分源程序已给出。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include int i,j,data; for(i=0;i<199;i++) for(j=i+1;j<200;j++) if(aa[i]00aa[j]) {data=aa[i];aa[i]=aa[j];aa[j]=data;} for(i=0;i<10;i++) bb[i]=aa[i]; } void main() { readDat(); jsSort(); writeDat(); system(\} readDat() { FILE *in; int i; in=fopen(\ for(i=0; i<200; i++) fscanf(in,\fclose(in); } writeDat() { 断点亡魂 薄观约取 厚积薄发 断点-影子 FILE *out; int i; clrscr(); out=fopen(\for(i=0; i<10; i++){ printf(\fprintf(out,\} fclose(out); } *************************************************************************** ☆题目7(结构体操作题) 已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能要求:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT6.DAT中。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include 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,data; for(i=0;i<199;i++) for(j=i+1;j<200;j++) if(aa[i]00aa[j]) {data=aa[i];aa[i]=aa[j];aa[j]=data;} for(i=0;i<10;i++) bb[i]=aa[i]; 断点亡魂 薄观约取 厚积薄发 断点-影子 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(void) { 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); 断点亡魂