首页 > 其他分享 >实验6

实验6

时间:2022-12-23 16:22:12浏览次数:34  
标签:fp no int STU 实验 printf t%

task.4

#include<stdio.h>
int main() {
char ch;
FILE* fp;

fp = fopen("data4.txt", "r");
if (fp == NULL) {
printf("fail to open file");
return 1;
}
int count = 0;
ch = fgetc(fp);
while (ch != EOF) {
if (ch != ' ' && ch != '\n' && ch != ' ')
count++;
ch = fgetc(fp);

}
printf("data4.txt中共包含字符数(不计空白符): %d", count);
fclose(fp);
return 0;
}

 

 

 

 

task.5

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

#define N 10

typedef struct {
long int id;
char name[20];
float objective; // 客观题得分
float subjective; // 操作题得分
float sum;
char level[10];
} STU;

// 函数声明
void input(STU s[], int n);
void output(STU s[], int n);
void process(STU s[], int n);

int main() {
STU stu[N];

printf("从文件读入%d个考生信息: 准考证号,姓名,客观题得分(<=40),操作题得分(<=60)\n", N);
input(stu, N);

printf("\n对考生信息进行处理: 计算总分,确定等级\n");
process(stu, N);

printf("\n打印考生完整信息, 并保存到文件中");
output(stu, N);

return 0;
}

// 从文本文件examinee.txt读入考生信息:准考证号,姓名,客观题得分,操作题得分
void input(STU s[], int n) {
int i;
FILE *fin;

fin = fopen("examinee.txt", "r");
if (fin == NULL) {
printf("fail to open file\n");
exit(0);
}

while (!feof(fin)) {
for (i = 0; i < n; i++)
fscanf(fin, "%ld %s %f %f", &s[i].id, s[i].name, &s[i].objective, &s[i].subjective);
}

fclose(fin);
}

// 输出考生完整信息: 准考证号,姓名,客观题得分,操作题得分,总分,等级
// 不仅输出到屏幕上,还写到文本文件result.txt中
void output(STU s[], int n) {
FILE *fout;
int i;

// 输出到屏幕
printf("\n");
printf("准考证号\t姓名\t客观题得分\t操作题得分\t总分\t\t等级\n");
for (i = 0; i < n; i++)
printf("%ld\t\t%s\t%.2f\t\t%.2f\t\t%.2f\t\t%s\n", s[i].id, s[i].name, s[i].objective, s[i].subjective, s[i].sum, s[i].level);

// 保存到文件
fout = fopen("result.txt", "w");
if (!fout) {
printf("fail to open or create result.txt\n");
exit(0);
}

fprintf(fout, "准考证号\t\t姓名\t客观题得分\t操作题得分\t总分\t\t等级\n");

for (i = 0; i < n; i++)
fprintf(fout, "%ld\t\t%s\t%.2f\t\t%.2f\t\t%.2f\t\t%s\n", s[i].id, s[i].name, s[i].objective, s[i].subjective, s[i].sum, s[i].level);

fclose(fout);
}

// 对考生信息进行处理:计算总分,排序,确定等级
void process(STU s[], int n) {
// 补足代码
// ×××
int i,j;
STU m;
for(i=0;i<n;++i){
s[i].sum=s[i].objective+s[i].subjective;
}
for(i=0;i<n-1;++i){
for(j=n-1;j>i;--j){
if(s[j].sum>s[j-1].sum){
m=s[j];
s[j]=s[j-1];
s[j-1]=m;

}
}
}
int k,a;
k=n*0.1;
a=n*0.5;
for(i=0;i<k;++i)
strcpy(s[i].level,"优秀");
for(i=k;i<a;++i)
strcpy(s[i].level,"合格");
for(i=a;i<n;++i)
strcpy(s[i].level,"不合格");

}

 

 

 

 task.6

#include<stdio.h>
#include<time.h>
#include<stdlib.h>
typedef struct {
long no;
char name[20];
char grade[20];
}STU;
int main(){
FILE *fp,*fp1;
STU s[80];
fp1=fopen("lucky.txt","w");
fp=fopen("list.txt","r");
if(fp==NULL){
printf("fail to open file");
return 1;
}
if(fp1==NULL){
printf("fail to open file");
return 1;
}
int i;
for(i=0;i<80;i++){
fscanf(fp,"%ld%s%s",&s[i].no,s[i].name,s[i].grade);
}
fclose(fp);
srand(time(NULL));
STU c[5];
int j,k;
for(i=0;i<5;i++){
c[i].no=204942000+(rand()%80+1);
}
for(j=0;j<5;j++){
for(k=0;k<80;k++){
if(s[k].no==c[j].no)
{
c[j]=s[k];
}
}
}
for(i=0;i<5;i++){
printf("%ld\t%s\t%s\n",c[i].no,c[i].name,c[i].grade);
fprintf(fp1,"%ld\t%s\t%s\n",c[i].no,c[i].name,c[i].grade);
}
fclose(fp1);
return 0;
}

 

 

 

 

 

 

 

 

#include<stdio.h>
#include<time.h>
#include<stdlib.h>
typedef struct {
long no;
char name[20];
char grade[20];
}STU;
int main ()
{
char buffer[80];
time_t rawtime = time(NULL);
struct tm *timer;
timer = localtime( &rawtime );
int year=timer->tm_year+1900;
int month=timer->tm_mon+1;
int day=timer->tm_mday;
strftime(buffer,80,"%Y%m%d.txt",timer);

FILE *fp,*fp1;
STU s[80];
fp1=fopen(buffer,"w");
fp=fopen("list.txt","r");
if(fp==NULL){
printf("fail to open file");
return 1;
}
if(fp1==NULL){
printf("fail to open file");
return 1;
}
int i;
for(i=0;i<80;i++){
fscanf(fp,"%ld%s%s",&s[i].no,s[i].name,s[i].grade);
}
fclose(fp);
srand(time(NULL));
STU c[5];
int j,k;
for(i=0;i<5;i++){
c[i].no=204942000+(rand()%80+1);
}
for(i=0;i<5;++i){
for(j=0;j<5;++j){
if(i==j)
continue;
if(c[i].no==c[j].no){
c[j].no=204942000+(rand()%80+1);
i=0;
break;
}
}
}
for(j=0;j<5;j++){
for(k=0;k<80;k++){
if(s[k].no==c[j].no)
{
c[j]=s[k];
}
}
}
for(i=0;i<5;i++){
printf("%ld\t%s\t%s\n",c[i].no,c[i].name,c[i].grade);
fprintf(fp1,"%ld\t%s\t%s\n",c[i].no,c[i].name,c[i].grade);
}
fclose(fp1);
return 0;
}

 

 

 

标签:fp,no,int,STU,实验,printf,t%
From: https://www.cnblogs.com/wjt666/p/17000955.html

相关文章

  • 实验6
    text4#define_CRT_SECURE_NO_WARNINGS#include<stdio.h>intmain(){FILE*fp;fp=fopen("D:\\.temp\\data4.txt","r");if(feof(fp)){p......
  • 火山引擎 DataTester 上线“流程画布”功能,支持组合型 A/B 实验分析
    更多技术交流、求职机会,欢迎关注字节跳动数据平台微信公众号,回复【1】进入官方交流群在精细化运营的时代,运营活动同样需要有精细化的策略,例如在年末大促活动中,设计APP......
  • 实验5
    实验1#include<stdio.h>#include<string.h>#defineN3typedefstructstudent{intid;charname[20];charsubj......
  • 实验5
    #include<stdio.h>#include<string.h>#include<stdlib.h>#defineN100typedefstruct{charnum[10];//学号ints1;//期末成绩ints2;//平时......
  • 实验二:简单的人机网络对话
    实验目的通过流式套接字编程,实现简单的人机网络对话程序。服务端预存对话模板,根据模板对客户端发来的会话进行应答。实验要求1.使用控制台界面编程。2.利用流式套接字......
  • 芯科BG22蓝牙芯片RAILtest测试实验
    一.如何创建RAILtest工程1.先打开SSV5,插入开发板,选择RAILtest程序:  2.创建工程   3.设置radio,正常情况下使用默认配置即可以跳过此步骤   4.设置......
  • R语言统计学DOE实验设计:用平衡不完全区组设计(BIBD)分析纸飞机飞行时间实验数据
    全文链接:http://tecdat.cn/?p=31010原文出处:拓端数据部落公众号平衡不完全区组设计(BIBD)是一个很好的研究实验设计,具有从统计的角度看各种所需的特征。最近我们被要求撰......
  • 实验八-Web部署
    实验八-Web部署最开始,我用自己的云服务器进行实验步骤如图:  经过下载和解压,进行里面内容的编辑,copy上去即可。  之后在访问ip/wp-config.php时......
  • 实验5
    1#include<stdio.h>2#include<string.h>3#defineN10045typedefstruct{6charnum[10];//学号7ints1;//期末......
  • 实验八-Web部署
    实验步骤在华为云openEuler安装后,没有配置yum源,我们通过重新配置。输入命令以切换到rpos目录下cd/etc/yum.repos.d输入命令更换yum源viopenEuler_x86_64.repo增......