0013 A Typical Homework (a.k.a Shi Xiong Bang Bang Mang) UVA - 12412

A Typical Homework (a.k.a Shi Xiong Bang Bang Mang) UVA - 12412

问题

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

代码

// 算法竞赛入门经典习题与解答 P
// 算法竞赛入门经典第2版 P
/*
    Dreams never shine!
    It's you that shine while chasing your dreams :)
    JAYO!!
*/
#include <stdio.h>
#include <string.h>
#define maxn 1000
#define maxl 100
#define EPS 1e-5

int n = 0;
char sid[maxn][maxl];
int cid[maxn];
char name[maxn][maxl];
int score[maxn][5];
int removed[maxn];

const char *course_name[] = {"Chinese", "Mathematics", "English", "Programming"};

int valid(int k) { // 是否已经有这条数据了,有为0, 没有为1(那么就添加add)
    for(int i = 0; i < k; i++) if(!removed[i]) { 
        if(strcmp(sid[i], sid[k]) == 0) return 0;
    }
    return 1;
}

void add() {
    for( ; ; ) {
        printf("Please enter the SID, CID, name and four scores. Enter 0 to finish.\n"); 
        scanf("%s", sid[n]);
        if(strcmp(sid[n], "0") == 0) break;
        scanf("%d%s%d%d%d%d", &cid[n], name[n], &score[n][0], &score[n][1], &score[n][2], &score[n][3]);
        if(valid(n)) {score[n][4] = score[n][0] + score[n][1] + score[n][2] + score[n][3]; n++;}
        else printf("Duplicated SID.\n");   
    }
}

int rank(int k) {
    int r = 0;
    for(int i = 0; i < n; i++) {
        if(!removed[i] && score[i][4] > score[k][4]) r++;
    }
    return r + 1;
}

void DQ(int isq) {
    char s[maxl];
    for(;;) {
        printf("Please enter SID or name. Enter 0 to finish.\n");
        scanf("%s", s);
        if(strcmp(s, "0") == 0) break;
        int r = 0;
        for(int i = 0; i < n; i++) if(!removed[i]) {
            if(strcmp(sid[i], s) == 0 || strcmp(name[i], s) == 0) {
                if(isq) printf("%d %s %d %s %d %d %d %d %d %.2f\n", rank(i), sid[i], cid[i], name[i], score[i][0], score[i][1], score[i][2], score[i][3], score[i][4], score[i][4] / 4.0 + EPS);
                else { removed[i] = 1; r++; }
            }
        }
        if(!isq) printf("%d student(s) removed.\n", r);
    }
}

double get_course_stat(int c, int s, int *passed, int *failed) { // c 是 class
    int tot = 0;
    *passed = *failed = 0;
    for(int i = 0; i < n; i++) {
        if(!removed[i] && (c == 0 || cid[i] == c)) {
            tot += score[i][s];
            if(score[i][s] >= 60) (*passed)++; else (*failed)++;
        }        
    }
    return (double)tot / (double)(*passed + *failed);
}

void get_overall_stat(int c, int *cnt) {
    cnt[0] = cnt[1] = cnt[2] = cnt[3] = cnt[4] = 0;
    for(int i = 0; i < n; i++) {
        if(!removed[i] && (c == 0 || cid[i] == c)) {
            int k = 0;
            for(int j = 0; j < 4; j++) if(score[i][j] >= 60) k++; // 检测每个学生的四门功课及格情况
            cnt[k]++; // 通过k门功课的学生
        }
    }
}

void stat() {
  int c;
  printf("Please enter class ID, 0 for the whole statistics.\n");
  scanf("%d", &c);
  for(int i = 0; i < 4; i++) {
    int passed, failed;
    double avg = get_course_stat(c, i, &passed, &failed);
    printf("%s\n", course_name[i]);
    printf("Average Score: %.2f\n", avg+EPS);
    printf("Number of passed students: %d\n", passed);
    printf("Number of failed students: %d\n", failed);
    printf("\n");
  }
  int cnt[5];
  get_overall_stat(c, cnt);

  printf("Overall:\n");
  printf("Number of students who passed all subjects: %d\n", cnt[4]);
  printf("Number of students who passed 3 or more subjects: %d\n", cnt[4]+cnt[3]);
  printf("Number of students who passed 2 or more subjects: %d\n", cnt[4]+cnt[3]+cnt[2]);
  printf("Number of students who passed 1 or more subjects: %d\n", cnt[4]+cnt[3]+cnt[2]+cnt[1]);        
  printf("Number of students who failed all subjects: %d\n", cnt[0]);
  printf("\n");
}

int main() {
    for( ; ; ) {
        int choice;
        // print_menu();
        printf("Welcome to Student Performance Management System (SPMS).\n");
        printf("\n");
        printf("1 - Add\n");
        printf("2 - Remove\n");
        printf("3 - Query\n");
        printf("4 - Show ranking\n");
        printf("5 - Show Statistics\n");
        printf("0 - Exit\n");
        printf("\n");

        scanf("%d", &choice);
        if(choice == 0) break;
        if(choice == 1) add();
        if(choice == 2) DQ(0);
        if(choice == 3) DQ(1);
        if(choice == 4) printf("Showing the ranklist hurts students' self-esteem. Don't do that.\n");
        if(choice == 5) stat();
    }
	return 0;
}


总结

注意大小写!注意空格!
一句话!注意细节!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值