【PAT】B1073 多选题常见计分法(20 分)
此处为我的存储结构,只提供一种思路,二维数组存储所有数据

#include<stdio.h>
#include<string.h>
#include<map>
#include<vector>
#include<algorithm>
using namespace std;
int ti[200][20]={0};
bool ffind(char *p,char c){
int len = strlen(p);
for(int i=0;i<len;i++){
if(p[i]==c) return true;
}
return false;
}
int main(){
int flag=0;//储存错的最多次数
int N,M;scanf("%d %d",&N,&M);
for(int i=1;i<=M;i++){
scanf("%d %d %d",&ti[i][0],&ti[i][1],&ti[i][2]);
for(int j=0;j<ti[i][2];j++){
char temp;scanf(" %c",&temp);
ti[i][temp-'a'+3]=1;
}
}
getchar();//接收换行
for(int i=0;i<N;i++){//N个学生,N次循环
double score=0;//当前学生成绩
for(int j=1;j<=M;j++){
int Tnum=0,ff=0;
char str[10];
scanf(" (%[^)]",str);
for(int k=3;k<=7;k++){
char temp=k-3+'a';
if(ffind(str,temp)==true){//选了
if(ti[j][k]==0){//错
ti[j][k+5]++;ff=1;
if(ti[j][k+5]>flag) flag=ti[j][k+5];
}else Tnum++;
}else{//没选
if(ti[j][k]==1){
ti[j][k+5]++;
if(ti[j][k+5]>flag) flag=ti[j][k+5];
}
}
}
if(ff==0){
if(Tnum==ti[j][2]) score+=ti[j][0];
if(Tnum<ti[j][2]){
score+=ti[j][0]/2.0;
}
}
getchar();//右括号
}
printf("%.1lf\n",score);
}
if(flag==0){
printf("Too simple");
return 0;
}
for(int i=1;i<=M;i++){
for(int j=8;j<=12;j++){
if(ti[i][j]==flag) printf("%d %d-%c\n",flag,i,j-8+'a');
}
}
return 0;
}
【PAT】B1073 多选题常见计分法(20 分)的更多相关文章
- PAT——1073. 多选题常见计分法(20)
批改多选题是比较麻烦的事情,有很多不同的计分方法.有一种最常见的计分方法是:如果考生选择了部分正确选项,并且没有选择任何错误选项,则得到50%分数:如果考生选择了任何一个错误的选项,则不能得分.本题就 ...
- 1073 多选题常见计分法 (20分)C语言
批改多选题是比较麻烦的事情,有很多不同的计分方法.有一种最常见的计分方法是:如果考生选择了部分正确选项,并且没有选择任何错误选项,则得到 50% 分数:如果考生选择了任何一个错误的选项,则不能得分.本 ...
- PAT 1073. 多选题常见计分法
PAT 1073. 多选题常见计分法 批改多选题是比较麻烦的事情,有很多不同的计分方法.有一种最常见的计分方法是:如果考生选择了部分正确选项,并且没有选择任何错误选项,则得到50%分数:如果考生选择了 ...
- PAT 1073 多选题常见计分法(20)(代码+思路)
1073 多选题常见计分法(20 分) 批改多选题是比较麻烦的事情,有很多不同的计分方法.有一种最常见的计分方法是:如果考生选择了部分正确选项,并且没有选择任何错误选项,则得到 50% 分数:如果考生 ...
- PAT 1073 多选题常见计分法 (20 分)
批改多选题是比较麻烦的事情,有很多不同的计分方法.有一种最常见的计分方法是:如果考生选择了部分正确选项,并且没有选择任何错误选项,则得到 50% 分数:如果考生选择了任何一个错误的选项,则不能得分.本 ...
- P1073 多选题常见计分法
P1073 多选题常见计分法 转跳点:
- PAT Basic 1073. 多选题常见计分法
题目内容 多选题常见计分法(20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 批改多选题是比较麻烦的事情,有 ...
- PAT (Advanced Level) Practice 1015 Reversible Primes (20 分) 凌宸1642
PAT (Advanced Level) Practice 1015 Reversible Primes (20 分) 凌宸1642 题目描述: A reversible prime in any n ...
- PAT (Advanced Level) Practice 1046 Shortest Distance (20 分) 凌宸1642
PAT (Advanced Level) Practice 1046 Shortest Distance (20 分) 凌宸1642 题目描述: The task is really simple: ...
随机推荐
- JAVA中的糕富帅技术——反射(一)
前言 突然发现好久没写博客了,前面写的都是关于Android的东西,今天心血来潮突然有一种冲动想写一篇基于JAVA技术的博客,别问我为什么?有钱.任性! 今天就来谈谈反射机制:学过JAVA的人不一定懂 ...
- TCP/IP 笔记 - 超时和重传
TCP协议为了提供可靠的数据传输服务,会启动数据重传来解决下层网络层(IP)可能出现的数据包丢失. 超时重传介绍 TCP重传由两套独立机制来完成重传,基于时间的超时重传(RTO,TCP发送数据时会设置 ...
- MySQL:对于几个测试题的详细研究
最近在做MySQL作业时候遇到了很多问题,MySQL作业链接:https://www.cnblogs.com/wj-1314/p/9213885.html 所以下面谈一下稍微难一点的数据库问题,我们需 ...
- SpringBoot自动配置注解原理解析
1. SpringBoot启动主程序类: @SpringBootApplication public class DemoApplication { public static void main(S ...
- Django之FBV与CBV
一.FBV与CBV FBV(function based views),即基于函数的视图:CBV(class based views),即基于类的视图,也是基于对象的视图.当看到这个解释时,我是很萌的 ...
- 数据库的DevOps实践
---------------------------------------------------------------------------------------------------- ...
- MVC 【ASPX视图引擎】
新建项目----ASP.NET MVC 4 Web 应用程序------选择模板(空).视图引擎(ASPX) 1.认识控制器Controller using System; using System. ...
- minitab 转换语言
在使用minitab的时候,我们会以中文版熟悉界面,但是我们在实际操作的时候就要使用英文版的功能. 那么如何改变其语言环境呢. 很简单: 工具->选项->语言
- php面向对象的接口和APP接口区别
以下是php面向对象的接口:
- 多语言网站利器 rel="alternate" hreflang="x"
下面是我在浏览网站时无意看到的,然后就搜了一下,感觉内容不错但我还没有测试,就转载过来做个备注,有时间了在翻过来看看 rel="alternate" hreflang=" ...