首页 > 其他分享 >实验7

实验7

时间:2024-06-21 14:56:41浏览次数:22  
标签:int printf st STU 实验 pass fin

task 4

#include <stdio.h>

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

    fclose(fp);

    printf("data4.txt中共包含字符数(不计空白符):%d\n", count);

    return 0;
}

task 5

#include<stdio.h>
#include<string.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_pass,cnt);
     foutput(stu_pass,cnt);

     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,cnt=0;
   for(i=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[cnt++] = st[i];
       }
       else
       strcpy(st[i].ans,"fail");

   }
    return cnt;
   
   
}

task 6

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <time.h>
#define M 100
#define N 80

typedef struct {
    long int id;
    char name[10];
    char c[20];
}STU;


int main(){
    STU st[M];
    int i,n;
    FILE *fin;
    FILE *fp;

    fin = fopen("list.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 %s",&st[i].id,st[i].name,st[i].c);
    }

    fp = fopen("lucky.txt", "wb");
    if(fp == NULL) {
        printf("fail to open file\n");
        return 1;
    }

    srand(time(0));
    for(i=0;i<5;i++){
    n=rand()%N;
    fprintf(fp,"%ld %-10s %-20s\n",st[n].id,st[n].name,st[n].c);
    printf("%ld %-10s %-20s\n",st[n].id,st[n].name,st[n].c);
    }

    fclose(fin);
    fclose(fp);
    return 0;
}

 

标签:int,printf,st,STU,实验,pass,fin
From: https://www.cnblogs.com/wp40032880/p/18260493

相关文章

  • 实验七
    TASK4#include<stdio.h>intmain(){ intcnt=0; charc; FILE*fp; fp=fopen("data4.txt","r"); if(fp==NULL){ printf("failtoopenthefile\n"); return1; } while((c=fgetc(fp))!=EOF){ if(c!='......
  • Linux 阻塞和非阻塞 IO 实验学习
    Linux阻塞和非阻塞IO实验学习IO指的是Input/Output,也就是输入/输出,是应用程序对驱动设备的输入/输出操作。当应用程序对设备驱动进行操作的时候,如果不能获取到设备资源,那么阻塞式IO就会将应用程序对应的线程挂起,直到设备资源可以获取为止。对于非阻塞IO,应用程序对应的线......
  • 阿里云Apsara Clouder专项技能认证——弹性计算Clouder认证:ECS快速入门(实验、考试操
    前言证书特点:免费!免费!免费!多一个证书有啥不好呢!!!证书名称:阿里ECS专项认证证书有效期:2年培训需求:免费培训,阿里提供课程发证机构:阿里巴巴考试时间:随时,线上直接考考试语言:中文考试费用:0考试难度:★★☆☆☆社会认可度:★★☆☆☆性价比:★★★★★(因为免费,性价比拉满)技术......
  • 实验7
    task4#include<stdio.h>intmain(){intcount=0;charch;FILE*fp;//以读的方式打开文本文件data1.txtfp=fopen("data4.txt","r");//如果打开文件失败,输出提示信息并返回if(fp==NULL){printf("fai......
  • 人工智能模型组合学习的理论和实验实践
        组合学习,即掌握将基本概念结合起来构建更复杂概念的能力,对人类认知至关重要,特别是在人类语言理解和视觉感知方面。这一概念与在未观察到的情况下推广的能力紧密相关。尽管它在智能中扮演着核心角色,但缺乏系统化的理论及实验研究方法,使得分析计算模型的组合学习能力......
  • 实验七
    点击查看代码#include<stdio.h>intmain(){intcount=0;intch;FILE*fp;fp=fopen("data4.txt","r");if(fp==NULL){printf("failtoopenfile\n");return1;}while((......
  • PXE高效批量网络装机(补充) 实验部分
    然后把防火墙、安全机制全都给关闭掉,不要让它们干扰后续的实验:然后安装那几个需要用到的软件包:如果重启了系统vsftpd是不能自动启动起来的,如果想让该服务每次开机都自动的启动起来,可以执行下图中的命令:注:在dhcp的配置文件里面需要指定一些TFTP的相关数据然后保......
  • 矿大数据结构 实验三
    A.二叉链表存储的二叉树定义节点---建立二叉树的函数---前序遍历函数---中序遍历函数#include<bits/stdc++.h>#definelllonglongusingnamespacestd;structNode{//节点,用char存储本身的数据,指针指向左右节点 chardata; Node*lc; Node*rc; Node......
  • 5.24实验三 数据库完整性、安全性实现
    实验三 数据库完整性、安全性实现一、实验目的:使学生加深对数据库安全性和完整性的理解,并掌握SQLServer中有关用户、角色及操作权限的管理方法,学会创建和使用规则、缺省和触发器以及存储过程。二、实验要求:通过实验对数据进行完整性控制、安全性维护。三、实验步骤:......
  • 5.27实验四 数据库的备份和恢复
    实验四 数据库的备份和恢复一、实验目的:熟悉并掌握数据库备份和恢复的原理和操作。二、实验要求:掌握存储设备的创建、使用。掌握数据库中数据的导入导出操作。掌握数据上的备份和恢复操作。掌握数据库备份策略的制定原理和具体操作。三、实验步骤:1、开始→程序→Micros......