首页 > 其他分享 >实验7

实验7

时间:2023-12-17 16:24:22浏览次数:29  
标签:fp int void st STU 实验 printf

test4

代码

#include<stdio.h>
#define N 2
int main(){
    char *x[N]={"0123456789-0123456789",
                "nuist2023 - nuist2024"
                };
    int i;
    FILE *fp;
    fp=fopen("data4.txt","w");
    if(fp==NULL){
        printf("fail to open file\n");
        return 1;
    }
    for(i=0;i<N;i++){
        fputs(x[i],fp);
        fputs("\n",fp);
    }
    fclose(fp);
    return 0;
}
#include<stdio.h>
int main(){
    char ch;
    int i=0;
    FILE *fp;
    fp=fopen("data4.txt","r");
    if(fp==NULL){
        printf("fail to open file\n");
        return 1;
    }
    while(1){
        ch=fgetc(fp);
        if(ch!=' '&&ch!='\n'&&ch!='\0'&&ch!='    '&&ch!=EOF){
            i++;
        }
        if(ch==EOF){
            break;
        }
        putchar(ch);
    }
    fclose(fp);
    printf("data4.txt中共包含字符数(不计空白符):%d",i);
    return 0;
}

 

运行结果

test5

代码

#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 ans[10];       // 考试结果
} STU;

// 函数声明
void finput(STU st[], int n);
void foutput(STU st[], int n);
void output(STU st[], int n);
int process(STU st[], int n, STU st_pass[]);

int main() {
    STU stu[N], stu_pass[N];
    int cnt;
    double pass_rate;

    printf("从文件读入%d个考生信息...\n", N);
    finput(stu, N);

    printf("\n对考生成绩进行统计...\n");
    cnt = process(stu, N, stu_pass);

    printf("\n通过考试的名单:\n");
    output(stu, N);      // 输出到屏幕
    foutput(stu, N);    // 输出到文件

    pass_rate = 1.0 * cnt / N;
    printf("\n本次等级考试通过率: %.2f%%\n", pass_rate*100);

    return 0;
}

// 把通过考试的考生完整信息输出到屏幕上
// 准考证号,姓名,客观题得分,操作题得分,总分,结果
void output(STU st[], int n) {
    int i;
    
    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", st[i].id, st[i].name, st[i].objective, st[i].subjective, st[i].sum, st[i].ans);
}

// 从文本文件examinee.txt读入考生信息:准考证号,姓名,客观题得分,操作题得分
void finput(STU st[], 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", &st[i].id, st[i].name, &st[i].objective, &st[i].subjective);
    }

    fclose(fin);
}

// 把通过考试的考生完整信息写入文件list_pass.txt
// 准考证号,姓名,客观题得分,操作题得分,总分,结果
void foutput(STU s[], int n) {
    FILE *fout;
    int i;
    
    // 保存到文件 
    fout = fopen("list_pass.txt", "w");
    if (!fout) {
        printf("fail to open or create list_pass.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].ans);

    fclose(fout);
}



// 对考生信息进行处理:计算每位考生考试总分、结果;统计考试通过的人数
int process(STU st[], int n, STU st_pass[]) {
    int i;
    int j;
    for(i=0,j=0;i<n;i++){
        st[i].sum=st[i].objective+st[i].subjective;
        if(st[i].sum>=60){
            strcpy(st[i].ans,"pass");
            st_pass[j++]=st[i];
        }else{
            strcpy(st[i].ans,"fall");
        }
    }
    return j;
}

 

运行结果

test6.1

代码#include<stdio.h>

#include<stdlib.h>
#include<time.h>
#define N 20
#define M 80
#define K 5
typedef struct{
    
    long int num;
    char name[N];
    char cla[N];
}STU;
void output(STU st[],int n);
void foutput(STU st[],int n);
void finput(STU st[],int n);
void luck(STU st[],int n,STU stl[]);
int main(){
    STU list[M],lucky[M];
    finput(list,M);
    luck(list,M,lucky);
    output(lucky,K);
    foutput(lucky,K);
    return 0;
}
void finput(STU st[],int n){
    int i;
    FILE *fp;
    fp=fopen("list.txt","r");
    if(fp==NULL){
        printf("wrong");
        exit(0);
    }
    while(!feof(fp)){
        for(i=0;i<n;i++){
            fscanf(fp,"%lld %s %s",&st[i].num,st[i].name,st[i].cla);
        }
    }
   fclose(fp); } void output(STU st[],int n){ int i; for(i=0;i<n;i++){ printf("%-10lld%-10s%-10s\n",st[i].num,st[i].name,st[i].cla);
  } } void foutput(STU st[],int n){ int i; FILE *fp; fp=fopen("lucky.txt","w"); for(i=0;i<n;i++){ fprintf(fp,"%-10lld%-10s%-10s",st[i].num,st[i].name,st[i].cla);
fprintf(fp,"\n"); }
   fclose(fp); } void luck(STU st[],int n,STU stl[]){ int i,j,k; srand(time(NULL)); for(i=0,k=0;i<n;i++){ j=rand()%M; stl[k++]=st[j]; } }

 

运行结果

 

test6.2

代码

 

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<time.h>
#define N 20
#define M 80
#define K 5
typedef struct{
    
    long int num;
    char name[N];
    char cla[N];
}STU;
void output(STU st[],int n);
void foutput(STU st[],int n);
void finput(STU st[],int n);
void luck(STU st[],int n,STU stl[]);
void sort(STU st[],int n);
int main(){
    STU list[M],lucky[M];
    finput(list,M);
    luck(list,M,lucky);
    sort(lucky,K);
    output(lucky,K);
    foutput(lucky,K);
    return 0;
}
void finput(STU st[],int n){
    int i;
    FILE *fp;
    fp=fopen("list.txt","r");
    if(fp==NULL){
        printf("wrong\n");
        exit(0);
    }
    while(!feof(fp)){
        for(i=0;i<n;i++){
            fscanf(fp,"%ld %s %s",&st[i].num,st[i].name,st[i].cla);
        }
    }
    fclose(fp);
}
void output(STU st[],int n){
    int i;
    for(i=0;i<n;i++){
        printf("%-10ld%-10s%-10s\n",st[i].num,st[i].name,st[i].cla);
    }
}
void foutput(STU st[],int n){
    int i;
    FILE *fp;
    char date[20]={0};
    time_t now;
    time(&now);
    strftime(date,sizeof(date),"%Y%m%d.txt",localtime(&now));
    fp=fopen(date,"w");
    for(i=0;i<n;i++){
        fprintf(fp,"%-10ld%-10s%-10s",st[i].num,st[i].name,st[i].cla);
        fprintf(fp,"\n");
    }
    fclose(fp);
}
void luck(STU st[],int n,STU stl[]){
    int flag[M]={0};
    int j,k;
    srand(time(NULL));
    for(k=0;k<n;){
        j=rand()%M;
        if(!flag[j]){
            stl[k++]=st[j];
            flag[j]=1;
        }
    }
}
void sort(STU st[],int n){
    int i,j;
    STU t;
    for(i=0;i<n-1;i++){
        for(j=0;j<n-1-i;j++){
            if(st[j].num>st[j+1].num){
                t=st[j];
                st[j]=st[j+1];
                st[j+1]=t;
            }
        }
    }
}

 

运行结果

 

 

标签:fp,int,void,st,STU,实验,printf
From: https://www.cnblogs.com/iamqy/p/17908910.html

相关文章

  • 实验6
    1#include<stdio.h>2#defineN1034typedefstruct{5charisbn[20];//isbn号6charname[80];//书名7charauthor[80];//作者8doublesales_price;//售价9intsales_count;//销售......
  • 实验三-电子公文传输系统1-个人贡献
    实验三-电子公文传输系统1-个人贡献1简述你完成的工作作为组长,分配任务到各个小组组员上,组织统筹组员完成各项工作。参与组内博客和文档的编写工作。参与后端设计的代码编写和加密通信过程的实现2你们小组总共的代码行数,你贡献的代码行数?相关代码链接?总共代码行数为5535......
  • 实验6
    任务4#include<iostream>#include"Vector.hpp"usingnamespacestd;template<typenameT>voidoutput(constVector<T>&v){for(autoi=0;i<v.get_size();i++){cout<<v.at(i)<<",";......
  • 实验6 C语言结构体、枚举应用编程
    实验任务1源代码:1#include<stdio.h>2#include<string.h>3#defineN10//运行程序输入测试时,可以把这个数组改小一些输入测试45typedefstructstudent{6intid;//学号7charname[20];//姓名8......
  • 实验六
    #pragmaonce#include<iostream>#include<stdexcept>usingnamespacestd;template<typenameT>classVector{private:intsize;T*ptr;public:Vector(intn):size{n}{if(n<0)throwstd::leng......
  • 实验7
    4.实验任务4task4.c源码:#define_CRT_SECURE_NO_WARNINGS#include<stdio.h>#include<stdlib.h>intmain(){FILE*fp;charch;intcnt=0;fp=fopen("data4.txt","r");if(fp==NULL){printf(&qu......
  • 实验6
    4.实验任务4task4.c源码#include<stdio.h>#defineN10typedefstruct{charisbn[20];//isbn号charname[80];//书名charauthor[80];//作者doublesales_price;//售价intsales_count;//销售册......
  • 鸿蒙小车之多任务调度实验
    说到鸿蒙我们都会想到华为mate60:遥遥领先!我们一直领先!我们这个小车也是采用的是鸿蒙操作系统,学习鸿蒙小车,让你遥遥领先于你的同学。@TOC前言本专栏将依次介绍鸿蒙小车的内核实验,硬件实验,wifi实验。一、什么是任务?为什么要有任务任务是操作系统(RTOS)中的基本组成单元,它们为嵌入式......
  • 实验七
    task4.c#include<stdio.h>intmain(){ charch; intcnt=0;FILE*fp;fp=fopen("data4.txt","r");if(fp==NULL){ printf("failtoopen\n"); return1; }while(1){ch=fgetc(fp);......
  • 实验6-模板类、文件I/O和异常处理
    Vector.hpp1#ifndefVECTOR_HPP2#defineVECTOR_HPP34#include<iostream>5#include<stdexcept>67template<classT>8classVector{9private:10T*arr;11intsize;1213public:14Vector():arr(nu......