博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Good Teacher(模拟)
阅读量:6039 次
发布时间:2019-06-20

本文共 2528 字,大约阅读时间需要 8 分钟。

Good Teacher

Time Limit:1000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu

   

I want to be a good teacher, so at least I need to remember all the student names. However, there are

too many students, so I failed. It is a shame, so I don’t want my students to know this. Whenever I
need to call someone, I call his CLOSEST student instead. For example, there are 10 students:
A ? ? D ? ? ? H ? ?
Then, to call each student, I use this table:
Pos Reference
1 A
2 right of A
3 left of D
4 D
5 right of D
6 middle of D and H
7 left of H
8 H
9 right of H
10 right of right of H
Input
There is only one test case. The first line contains n, the number of students (1 ≤ n ≤ 100). The next
line contains n space-separated names. Each name is either ‘?’ or a string of no more than 3 English
letters. There will be at least one name not equal to ‘?’. The next line contains q, the number of
queries (1 ≤ q ≤ 100). Then each of the next q lines contains the position p (1 ≤ p ≤ n) of a student
(counting from left).
Output
Print q lines, each for a student. Note that ‘middle of X and Y ’ is only used when X and Y are
both closest of the student, and X is always to his left.
Sample Input

10

A ? ? D ? ? ? H ? ?
4
3
8
6
10
Sample Output
left of D
H
middle of D and H
right of right of H

题解:老师点名,由于一些同学不认识名字,所以要找离他最近的同学代替,题中的I call his CLOSEST student instead;

还有一点就是两个同学中间,但是这两个同学间不能有人。。。

代码:

#include
#include
#include
#include
#include
#include
using namespace std;string name[110];map
ans;int p[110];bool js(int i){ if(ans.count(i) == 0) return true; else return false;}int main(){ int n, q; while(~scanf("%d", &n)){ int tp = 0; ans.clear(); for(int i = 1; i <= n; i++){ cin >> name[i]; if(name[i] != "?"){ ans[i] = name[i]; p[tp++] = i; } } for(int i = 0; i < tp - 1; i++){ if((p[i + 1] + p[i]) % 2 == 0 && js((p[i + 1] + p[i])/2)) ans[(p[i + 1] + p[i])/2] = "middle of " + name[p[i]] + " and " + name[p[i + 1]]; } for(int i = 1; i <= n; i++){ if(ans.count(i) == 0){ int x = lower_bound(p, p + tp, i) - p; int cnt, cnt1; if(x == 0){ cnt = p[0] - i; while(cnt--){ ans[i] = "left of " + ans[i]; } ans[i] += name[p[0]]; } else{ cnt = i - p[x - 1]; if(x < tp)cnt1 = p[x] - i; if(x == tp || cnt < cnt1){ while(cnt--){ ans[i] = "right of " + ans[i]; } ans[i] += name[p[x - 1]]; } else{ while(cnt1--){ ans[i] = "left of " + ans[i]; } ans[i] += name[p[x]]; } } } } int q, x; scanf("%d", &q); while(q--){ scanf("%d", &x); cout << ans[x] << endl; } } return 0;}

 

转载地址:http://xzghx.baihongyu.com/

你可能感兴趣的文章
用Python机器学习搞定验证码
查看>>
我是技术宅屌丝购物我只选爆款特卖
查看>>
tomcat7.0安装与配置及发布工程
查看>>
CoreOS实践指南(七):Docker容器管理服务
查看>>
《netty入门与实战》笔记-05:netty内置的channelHandler
查看>>
计算机语言&Python解释器
查看>>
GPU渲染简介
查看>>
python爬取人脸识别图片数据集/python爬去图片/python爬虫
查看>>
sed 和 vim的用法
查看>>
没有公网ip的解决方法
查看>>
html5 sessionStorage 与 localStorage使用详解
查看>>
hbase寻址机制详解
查看>>
nginx反代httpd,实现三种tomcat代理模型至后端的tomcat服务器,会话绑定的三种方式...
查看>>
Mysql 增量备份脚本 innobackupex 增量备份 mysql自动备份
查看>>
Python 之 Json模块使用
查看>>
权限设计中的数据灵活存储设计策略参考[以不变应万变]
查看>>
python列表生成器与生成器
查看>>
HSRP
查看>>
Linux ls命令
查看>>
tkinter_一个简单的窗口
查看>>