这应该是比较简单的一个模拟题,但是考试的时候花了较长的时间,并且最后一个case没过,丢了6分。这题的通过率不高,可见最后一个case还是有挑战性的。

考试的时候想的是在录数据的时候建立一个【ID】到【成绩信息】的映射,但是看网上代码用一个数组来录信息,然后建立【ID】到【数组索引】的映射。根据我的想法反正最后一个case根本过不了,可能只能按照网上博客的思路才行。


考试时的代码(最后一个case报错):

#include <stdio.h>
#include <memory.h>
#include <math.h>
#include <string>
#include <vector>
#include <set>
#include <stack>
#include <queue>
#include <algorithm>
#include <map> #define I scanf
#define OL puts
#define O printf
#define F(a,b,c) for(a=b;a<c;a++)
#define FF(a,b) for(a=0;a<b;a++)
#define FG(a,b) for(a=b-1;a>=0;a--)
#define LEN 501
#define MAX 0x06FFFFFF using namespace std; typedef struct Student{
string name;
int gp,gm,gf,G;
Student(){
gp=,gm=,gf=,G=;
}
Student(string n,int p,int m,int f,int g){
name=n;
gp=p,gm=m,gf=f,G=g;
}
bool operator < (Student const & o)const
{
if(G<o.G) return true;
else if(G==o.G) return name<o.name;
}
}Student;
Student output[]; #define MAP map<string,Student*> MAP info;
bool cmp(Student a,Student b); int main() {
freopen("d:/input/A1137.txt","r",stdin);
int P,M,F,t;
char buffer[];
scanf("%d %d %d",&P,&M,&F);
while(P-->){
I("%s",buffer);
scanf("%d",&t);
string name(buffer);
MAP::iterator it=info.find(name);
Student * tmp;
if(it==info.end()){
tmp=new Student;
tmp->gp=t;
tmp->name=name;
info[name]=tmp;
}else{
tmp=it->second;
tmp->gp=t;
}
}
while(M-->){
I("%s",buffer);
scanf("%d",&t);
string name(buffer);
MAP::iterator it=info.find(name);
Student * tmp;
if(it==info.end()){
tmp=new Student;
tmp->gm=t;
tmp->name=name;
info[name]=tmp;
}else{
tmp=it->second;
tmp->gm=t;
}
}
while(F-->){
I("%s",buffer);
scanf("%d",&t);
string name(buffer);
MAP::iterator it=info.find(name);
Student * tmp;
if(it==info.end()){
tmp=new Student;
tmp->gf=t;
tmp->name=name;
info[name]=tmp;
}else{
tmp=it->second;
tmp->gf=t;
}
}
int n,i=;
MAP::iterator it=info.begin();
while(it!=info.end()){
Student * p=it->second;
int gp,gm,gf,G;
gp=p->gp;gm=p->gm,gf=p->gf;
string name=p->name;
if(!(gp< || gf< || gf >)){
if(gm==) gm=-;
if(gf>=gm) G=gf;
else{
G=round(0.4*(double)gm+0.6*(double)gf);
}
output[i++]=Student(name,gp,gm,gf,G);
}
it++;
}
n=i;
sort(output,output+n,cmp);
FF(i,n){
O("%s %d %d %d %d\n",output[i].name.c_str(),output[i].gp,output[i].gm,output[i].gf,output[i].G);
}
return ;
} bool cmp(Student a,Student b){
if(a.G>b.G) return true;
else if(a.G==b.G) return a.name<b.name;
return false;
}

参考网上博客后AC的代码:

#include <stdio.h>
#include <memory.h>
#include <math.h>
#include <string>
#include <vector>
#include <set>
#include <stack>
#include <queue>
#include <algorithm>
#include <map> #define I scanf
#define OL puts
#define O printf
#define F(a,b,c) for(a=b;a<c;a++)
#define FF(a,b) for(a=0;a<b;a++)
#define FG(a,b) for(a=b-1;a>=0;a--)
#define LEN 501
#define MAX 0x06FFFFFF using namespace std; typedef struct Student{
string name;
int gp,gm,gf,G;
Student(){
gp=,gm=,gf=,G=;
}
Student(string n,int p,int m,int f,int g){
name=n;
gp=p,gm=m,gf=f,G=g;
}
}Student; Student students[]; #define MAP map<string,int> MAP name2index; bool cmp(Student a,Student b); int main() {
freopen("d:/input/A1137.txt","r",stdin);
int P,M,F,t;
char buffer[];
scanf("%d %d %d",&P,&M,&F);
int cnt=;
while(P-->){
I("%s",buffer);
scanf("%d",&t);
string name(buffer);
if(t>=){
name2index[name]=cnt;
students[cnt++]=Student(name,t,-,-,-);
}
}
while(M-->){
I("%s",buffer);
scanf("%d",&t);
string name(buffer);
int index=name2index[name];
if(index>){
students[index].gm=t;
}
}
while(F-->){
I("%s",buffer);
scanf("%d",&t);
string name(buffer);
int index=name2index[name];
if(index>){
students[index].gf=t;
}
}
int i;
FF(i,cnt){
Student &tmp=students[i];
if(tmp.gf>=tmp.gm) tmp.G=tmp.gf;
else{
double t=tmp.gm*+tmp.gf*;
t/=;t+=0.5;
tmp.G=t;
}
if(tmp.G<) tmp.G=-;
}
sort(students+,students+cnt,cmp);
F(i,,cnt+){
if(students[i].G>=)
O("%s %d %d %d %d\n",students[i].name.c_str(),
students[i].gp,students[i].gm,students[i].gf,students[i].G);
}
return ;
} bool cmp(Student a,Student b){
if(a.G==-) return false;
if(a.G>b.G) return true;
else if(a.G==b.G) return a.name<b.name;
return false;
}

需要注意的点:

  1.数组长度应该设置为1e5,否则段错误。

2. sort的第二个参数调试的时候脑抽写错了。students数组存储元素的范围是[1,cnt),第二个参数我脑抽写成了students+cnt+1

3. 判断成绩是否有效的判断语句也写错了。及格应该是大于等于,写成>60第二个和最后一个case过不了。

A1137 | 录数据查询模拟的更多相关文章

  1. Django models .all .values .values_list 几种数据查询结果的对比

    Django models .all .values .values_list 几种数据查询结果的对比

  2. MVC实用架构设计(三)——EF-Code First(4):数据查询

    前言 首先对大家表示抱歉,这个系列已经将近一个月没有更新了,相信大家等本篇更新都等得快失望了.实在没办法,由于本人水平有限,写篇博客基本上要大半天的时间,最近实在是抽不出这么长段的空闲时间来写.另外也 ...

  3. 关系数据库SQL之高级数据查询:去重复、组合查询、连接查询、虚拟表

    前言 接上一篇关系数据库SQL之基本数据查询:子查询.分组查询.模糊查询,主要是关系型数据库基本数据查询.包括子查询.分组查询.聚合函数查询.模糊查询,本文是介绍一下关系型数据库几种高级数据查询SQL ...

  4. SharePoint服务器端对象模型 之 使用CAML进展数据查询

    SharePoint服务器端对象模型 之 使用CAML进行数据查询 一.概述 在SharePoint的开发应用中,查询是非常常用的一种手段,根据某些筛选.排序条件,获得某个列表或者某一些列表中相应的列 ...

  5. .NET应用架构设计—面向查询服务的参数化查询设计(分解业务点,单独配置各自的数据查询契约)

    阅读目录: 1.背景介绍 2.对业务功能点进行逻辑划分(如:A.B.C分别三个业务点) 2.1.配置映射关系,对业务点配置查询契约(构造VS插件方便生成查询契约) 2.2.将配置好的映射策略文件放在调 ...

  6. Yii2 数据查询

    转载来自: http://www.yiichina.com/tutorial/95 数据查询 User::find()->all(); 此方法返回所有数据: User::findOne($id) ...

  7. 6、SQL Server 数据查询

    一.使用SELECT检索数据 数据查询是SQL语言的中心内容,SELECT 语句的作用是让数据库服务器根据客户要求检索出所需要的信息资料,并按照规定的格式进行整理,返回给客户端. SELECT 语句的 ...

  8. SQL Server 的表数据简单操作(表数据查询)

    --表数据查询----数据的基本查询-- --数据简单的查询--select * | 字段名[,字段名2, ...] from 数据表名 [where 条件表达式] 例: use 商品管理数据库 go ...

  9. asp.net mvc 数据查询赋值到文本框中

    大家做了很多文本框查询并且赋值回来 1.先是把数据对象查询结果后台,然后把对象赋值给对象在赋值回来前台页面 2.使用@html helerper 数据查询,使用 ViewContext.RouteDa ...

随机推荐

  1. 基于netty手写RPC框架

    代码目录结构 rpc-common存放公共类 rpc-interface为rpc调用方需要调用的接口 rpc-register提供服务的注册与发现 rpc-client为rpc调用方底层实现 rpc- ...

  2. Linux学习笔记之Centos7 自定义systemctl服务脚本

    0x00 概述 之前工作环境一直使用Centos6版本,脚本一直在使用/etc/init.d/xxx:系统升级到Cento7后,虽然之前的启动脚本也可以使用,但一直没有使用systemctl 的自定义 ...

  3. 第二章 Maven 构建 Java Web项目

    本教程中,我们将教给大家如何创建一个基于Spring MVC 的 Maven Web Project. 用到的技术/工具: 1.Eclipse 4.9 2.Maven 3.6.2 3.Tomcat 8 ...

  4. QCache 缓存(类似于map的模板类,逻辑意义上的缓存Cache,方便管理,默认类似于LRU的淘汰算法)

    最近在学习缓存方面的知识,了解了缓存(Cache)的基本概念,为什么要使用缓存,以及一些缓存算法(缓存替换),如LRU.LFU.ARC等等. 这些缓存算法的实现过程会使用一些基本的数据结构,如list ...

  5. Executor的线程代码

    package com.open1111; import java.util.concurrent.ExecutorService;import java.util.concurrent.Execut ...

  6. MySQL与Oracle的隔离级别

    一.事务和隔离级别 事务的概念:事务是把对数据库的一系列操作都看做一个整体,要么全部成功,要么全部失败,利用事务我们可以保证数据库的完整性,事务具有原子性. 隔离级别:隔离级别定义了事务与事务之间的隔 ...

  7. crontab定时任务不执行,单独运行sh生效

    虽然已经从事运维两三年了. 但是今天写的计划任务没有执行,排除了下, 这里整理下,方便后期查看. 排除思路 1. 确保crond服务是开机自启和当前是启动的. # centos systemctl s ...

  8. (三)Kubernetes 快速入门

    Kubernetes的核心对象 API Server提供了RESTful风格的编程接口,其管理的资源是Kubernetes API中的端点,用于存储某种API对象的集合,例如,内置Pod资源是包含了所 ...

  9. 项目Beta冲刺(团队) --3/7

    课程名称:软件工程1916|W(福州大学) 作业要求:项目Beta冲刺 团队名称:葫芦娃队 作业目标:进行新一轮的项目冲刺,尽力完成并完善项目 团队博客 队员学号 队员昵称 博客地址 04160242 ...

  10. 20180530模拟赛T2——绀碧之棺

    题目背景 qiancl 得到了一张藏宝图,上面写了一道谜题. 题目描述 定义\(F(n)\)为 n 在十进制下各个数位的平方和,求区间\([a,b]\)中有多少\(n\)满足\(k\times F(n ...