#include<stdio.h>
#include<stdlib.h>
#define BufLen 20
#define KeChengCount 3
typedef struct tagStuInfor
{
char xh[BufLen]//学号
char xm[BufLen]/漏早/姓名
char kchm[KeChengCount][BufLen]//课程名
float pshchj[KeChengCount]//平时成绩
float kshchj[KeChengCount]//考试成绩
float zpchj[KeChengCount]//总评成绩
float zf
}StudentInformation
typedef struct tagBookInfor
{
char shm[BufLen]//书名
float dj//单价
}BookInformation
void shurustu()
void zongfen()
void shuchumaxmin()
void sortbook()
void freeall()
//学生数,书数
int xshsh,shsh
StudentInformation *ptstu=NULL
BookInformation *ptbook=NULL
int main()
{
char in[]="data.txt",out[]="T_data.txt"
int i
float chjs[6],zf
FILE *fin,*fout
printf("250这个数字太不好了,能换成350吗?\n\n")
shurustu()
zongfen()
shuchumaxmin()
printf("请输入书数:")
scanf("%d",&shsh)
ptbook=(BookInformation*)calloc(shsh,sizeof(BookInformation))
for(i=0i<shshi++)
{
printf("请输入第%d本书的书名:",i+1)
scanf("%s",ptbook[i].shm)
printf("请输入第%d本书的单念纳价:",i+1)
scanf("%f",&ptbook[i].dj)
}
printf("\n")
sortbook()
printf("按书的单价升序排序后的结果:\n书名\t单价\n")
for(i=0i<shshi++)
{
printf("%s\t%.2f\n",ptbook[i].shm,ptbook[i].dj)
}
fin=fopen(in,"返高雀r")
fout=fopen(out,"w")
while(!feof(fin))
{
for(i=0i<6i++)
{
fscanf(fin,"%f",&chjs[i])
}
zf=0.2*(chjs[0]+chjs[1]+chjs[2])+0.8*(chjs[3]+chjs[4]+chjs[5])
printf("%.2f\n",zf)
fprintf(fout,"%.2f\r\n",zf)
}
printf("\n")
fclose(fin)
fclose(fout)
freeall()
system("PAUSE")
return EXIT_SUCCESS
}
void shurustu()
{
int i
printf("请输入学生的个数:")
scanf("%d",&xshsh)
ptstu=(StudentInformation*)calloc(xshsh,sizeof(StudentInformation))
for(i=0i<xshshi++)
{
strcpy(ptstu[i].kchm[0],"C语言")
strcpy(ptstu[i].kchm[1],"高等数学")
strcpy(ptstu[i].kchm[2],"英语")
printf("请输入第%d个学生的学号:",i+1)
scanf("%s",ptstu[i].xh)
printf("请输入第%d个学生的姓名:",i+1)
scanf("%s",ptstu[i].xm)
printf("请输入第%d个学生的C语言课程的平时成绩和考试成绩:",i+1)
scanf("%f %f",&ptstu[i].pshchj[0],&ptstu[i].kshchj[0])
printf("请输入第%d个学生的高等数学课程的平时成绩和考试成绩:",i+1)
scanf("%f %f",&ptstu[i].pshchj[1],&ptstu[i].kshchj[1])
printf("请输入第%d个学生的英语课程的平时成绩和考试成绩:",i+1)
scanf("%f %f",&ptstu[i].pshchj[2],&ptstu[i].kshchj[2])
}
printf("\n")
}
void zongfen()
{
int i
for(i=0i<xshshi++)
{
ptstu[i].zpchj[0]=0.2*ptstu[i].pshchj[0]+0.8*ptstu[i].kshchj[0]
ptstu[i].zpchj[1]=0.2*ptstu[i].pshchj[1]+0.8*ptstu[i].kshchj[1]
ptstu[i].zpchj[2]=0.2*ptstu[i].pshchj[2]+0.8*ptstu[i].kshchj[2]
ptstu[i].zf=ptstu[i].zpchj[0]+ptstu[i].zpchj[1]+ptstu[i].zpchj[2]
printf("%s的%s,%s,%s的总评成绩是:",ptstu[i].xm,ptstu[i].kchm[0],ptstu[i].kchm[1],ptstu[i].kchm[2])
printf("%.2f,%.2f,%.2f\n",ptstu[i].zpchj[0],ptstu[i].zpchj[1],ptstu[i].zpchj[2])
printf("%s的总分是:%.2f\n",ptstu[i].xm,ptstu[i].zf)
}
printf("\n")
}
void shuchumaxmin()
{
int i,min,max
min=max=0
for(i=1i<xshshi++)
{
if(ptstu[i].zf<ptstu[min].zf)
{
min=i
}
if(ptstu[i].zf>ptstu[max].zf)
{
max=i
}
}
printf("总分最高的学生的信息:\n学号\t姓名\t")
printf("%s(平时)\t%s(平时)\t%s(平时)",ptstu[max].kchm[0],ptstu[max].kchm[1],ptstu[max].kchm[2])
printf("\t%s(考试)\t%s(考试)\t%s(考试)\t总分\n",ptstu[max].kchm[0],ptstu[max].kchm[1],ptstu[max].kchm[2])
printf("%s\t%s\t",ptstu[max].xh,ptstu[max].xm)
printf("%.2f\t%.2f\t%.2f\t",ptstu[max].pshchj[0],ptstu[max].pshchj[1],ptstu[max].pshchj[2])
printf("%.2f\t%.2f\t%.2f\t%.2f\n\n",ptstu[max].kshchj[0],ptstu[max].kshchj[1],ptstu[max].kshchj[2],ptstu[max].zf)
printf("总分最低的学生的信息:\n学号\t姓名\t")
printf("%s(平时)\t%s(平时)\t%s(平时)",ptstu[min].kchm[0],ptstu[min].kchm[1],ptstu[min].kchm[2])
printf("\t%s(考试)\t%s(考试)\t%s(考试)\t总分\n",ptstu[min].kchm[0],ptstu[min].kchm[1],ptstu[min].kchm[2])
printf("%s\t%s\t",ptstu[min].xh,ptstu[min].xm)
printf("%.2f\t%.2f\t%.2f\t",ptstu[min].pshchj[0],ptstu[min].pshchj[1],ptstu[min].pshchj[2])
printf("%.2f\t%.2f\t%.2f\t%.2f\n\n",ptstu[min].kshchj[0],ptstu[min].kshchj[1],ptstu[min].kshchj[2],ptstu[min].zf)
}
void sortbook()
{
int i,j,min
BookInformation t
for(i=0i<shsh-1i++)
{
min=i
for(j=i+1j<shshj++)
{
if(ptbook[j].dj<ptbook[min].dj)
{
min=j
}
}
t=ptbook[i]
ptbook[i]=ptbook[min]
ptbook[min]=t
}
}
void freeall()
{
if(NULL!=ptstu)
{
free(ptstu)
}
if(NULL!=ptbook)
{
free(ptbook)
}
}
//data.txt文件
50 65 70 88 97 80
66 87 95 46 88 97
77 82 65 58 91 58
78 87 91 48 66 70
#include<stdio.h>void main()
{ float f=555.5678,ff
int a[10]={ 0,1,2,3,4,5,6,7,8,9 },b[10],i
FILE *fp
if ( fp=fopen("TEXT.dat","wb+") )
{ fwrite(&f,sizeof(float),1,fp)
for ( i=0i<10i++ ) fwrite(&a[i],sizeof(int),1,fp)
fclose(fp)
} else printf("无法拿携建立文纯敏橡件。\n")goto ERROREND
if ( fp=fopen("TEXT.dat"做旁,"rb") )
{ fread(&ff,sizeof(float),1,fp)
for ( i=0i<10i++ ) fread(&b[i],sizeof(int),1,fp)
fclose(fp)
} else printf("无法打开文件。\n")goto ERROREND
printf("%.2f ",ff)for ( i=0i<10i++ ) printf("%d ",b[i])printf("\n")
ERROREND:
}
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#ifdef BUFSIZ
#undef BUFSIZ
#define BUFSIZ 4096
#endif
/*
使用格式:mcpy 源文件 目标文件
且目标文件和源文件不能一样,否则会清空文件内容,
源文件必须存在,目标文件可存在也可不存在,如果存在,内容会被覆好旁盖掉。
*/
int main(int argc,char **argv)
{
char buf[BUFSIZ]
int msglen
if(argc!=3||strcmp(argv[1],argv[2])==0)
/*argc:命令行模式下,输入的橡消参数数目。
argv:第一个参数的首地址。*/
{
fprintf(stderr,"********************************\n\n")
fprintf(stderr,"Please usage:%s source_file destination_file\nAnd source_file is different from destination_file\n\n",argv[0])
fprintf(stderr,"********************************\n")
exit(0)
}
FILE *fp_src,*fp_des
if((fp_src=fopen(argv[1],"r"))==NULL)
/*为空,则打开失败*/
{
fprintf(stderr,"open %s failed!\n",argv[1])
exit(1)
}
if((fp_des=fopen(argv[2],"w"))==NULL)
/*为空,则打开或创建失败*/
{
fprintf(stderr,"open/create %s 友如橡failed!\n",argv[2])
exit(2)
}
while(fgets(buf,BUFSIZ,fp_src)!=NULL)
/*从源文件读,读失败或到达文件尾部时,返回NULL*/
{
if(fputs(buf,fp_des)==EOF)
/*写入目标文件,写入失败时,返回EOF;若成功返回写入的字节数*/
{
fprintf(stderr,"copy %s to %s failed!\n",argv[1],argv[2])
exit(3)
}
}
printf("copy %s to %s successful!\n",argv[1],argv[2])
return 0
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)