csuoj 1334: 好老师
http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1334
1334: 好老师
Time Limit: 1 Sec  Memory Limit: 128 MB
Submit: 525  Solved: 235
[Submit][Status][Web Board]
Description
我想当一个好老师,所以我决定记住所有学生的名字。可是不久以后我就放弃了,因为学生太多了,根本记不住。但是我不能让我的学生发现这一点,否则会很没面子。所以每次要叫学生的名字时,我会引用离他最近的,我认得的学生。比如有10个学生:
A ? ? D ? ? ? H ? ?
想叫每个学生时,具体的叫法是:
| 
 位置  | 
 叫法  | 
| 
 1  | 
 A  | 
| 
 2  | 
 right of A (A右边的同学)  | 
| 
 3  | 
 left of D (D左边的同学)  | 
| 
 4  | 
 D  | 
| 
 5  | 
 right of D (D右边的同学)  | 
| 
 6  | 
 middle of D and H (D和H正中间的同学)  | 
| 
 7  | 
 left of H (H左边的同学)  | 
| 
 8  | 
 H  | 
| 
 9  | 
 right of H (H右边的同学)  | 
| 
 10  | 
 right of right of H (H右边的右边的同学)  | 
Input
输入只有一组数据。第一行是学生数n(1<=n<=100)。第二行是每个学生的名字,按照从左到右的顺序给出,以空格分隔。每个名字要么是不超过3个英文字母,要么是问号。至少有一个学生的名字不是问号。下一行是询问的个数q(1<=q<=100)。每组数据包含一个整数p(1<=p<=n),即要叫的学生所在的位置(左数第一个是位置1)。
Output
对于每个询问,输出叫法。注意"middle of X and Y"只有当被叫者有两个最近的已知学生X和Y,并且X在Y的左边。
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
HINT
分析:
左右逐个扩展,知道找到!?时。
一开始wa了一次,因为忘了考虑这种数据:? ? ? ? asdf(就是当字符开始就是?的时候)
#include <stdio.h>
#include <algorithm>
#include <iostream>
#include <string.h>
#include <string>
#include <math.h>
#include <stdlib.h>
#include <queue>
#include <stack>
#include <set>
#include <map>
#include <list>
#include <iomanip>
#include <vector>
#pragma comment(linker, "/STACK:1024000000,1024000000")
#pragma warning(disable:4786) using namespace std; const int INF = 0x3f3f3f3f;
const int MAX = + ;
const double eps = 1e-;
const double PI = acos(-1.0); string str;
map<int , string>ma;
int main()
{
int n , i;
while(~scanf("%d",&n))
{
for(i = -;i <= ;i ++)
ma[i] = "?";
for(i = ;i <= n;i ++)
{
cin >> str;
ma[i] = str;
}
int m;
scanf("%d",&m);
int temp;
while(m --)
{
scanf("%d",&temp);
if(ma[temp] != "?")
cout << ma[temp] << endl;
else
{
int j;
for(j = ; ; j ++)
{
if(ma[temp + j] != "?" && ma[temp - j] != "?")
{
cout << "middle of " << ma[temp - j] << " and " << ma[temp + j] <<endl;
break;
}
else if(ma[temp + j] != "?" && j + temp <= n)
{
for(int k = ;k < j ;k ++)
cout << "left of ";
cout << ma[temp + j] << endl;
break;
}
else if(ma[temp - j] != "?" && temp - j >= )
{
for(int k = ;k < j ;k ++)
cout << "right of ";
cout << ma[temp - j] << endl;
break;
}
}
}
}
}
return ;
}
csuoj 1334: 好老师的更多相关文章
- CSU - 1334 -好老师(STL-map用法)
		
https://cn.vjudge.net/contest/157163#problem/E #include<map> #include<queue> #include< ...
 - Redis的Python实践,以及四中常用应用场景详解——学习董伟明老师的《Python Web开发实践》
		
首先,简单介绍:Redis是一个基于内存的键值对存储系统,常用作数据库.缓存和消息代理. 支持:字符串,字典,列表,集合,有序集合,位图(bitmaps),地理位置,HyperLogLog等多种数据结 ...
 - bzoj 1334: [Baltic2008]Elect
		
Description N个政党要组成一个联合内阁,每个党都有自己的席位数. 现在希望你找出一种方案,你选中的党的席位数要大于总数的一半,并且联合内阁的席位数越多越好. 对于一个联合内阁,如果某个政党 ...
 - 潭州学院-JavaVIP的Javascript的高级进阶-KeKe老师
		
潭州学院-JavaVIP的Javascript的高级进阶-KeKe老师 讲的不错,可以学习 下面是教程的目录截图: 下载地址:http://www.fu83.cn/thread-283-1-1.htm ...
 - 监控阮一峰老师的blog
		
引言 阮一峰大家基本都认识,很厉害的一个人,经济学博士,文章写得很棒,知识面很广泛,计算机.算法.英语.文采,这是能想到的他的一些标签,他的博客应该算是最受欢迎的博客之一了. 我经常回去看他的博客,但 ...
 - java抽象-老师的生日-逻辑思维-有趣的面试题-遁地龙卷风
		
(-1)写在前面 都快去北京了,硬生生的安排一场java考试,对于那些特别细节的东西我忘了吧也不觉得有什么不好,以前都记得,也都见过,只不过平时不常用连接断了,但是你死记硬背是没用的,一段时间后还是会 ...
 - 数据库中老师学生家长表添加自动同意好友自动(AgreeAddingFriend ),默认为True
		
数据库中老师学生家长表添加自动同意好友自动(AgreeAddingFriend ),默认为True alter table Sys_User add AgreeAddingFriend bit alt ...
 - 校内通知-Notifications表增加老师,家长,学生发送范围字段
		
老师发送范围:TReceiveRange 家长发送范围:PReceiveRange 学生发送范围:SReceiveRange alter table Notifications add TReceiv ...
 - 家教O2O维护“老师”的逼格,算不尊重市场吗
		
既然做O2O,本身就是把这当服务业的.出钱的人才是老大.老师受到尊重是因为你传授的东西他人认可,而不该是因为“老师”两个字.另外,成年人会去请家教的,往往是自己有一些长处的.你只是一方面的老师,人家可 ...
 
随机推荐
- OpenMP并行编程
			
什么是OpenMP?“OpenMP (Open Multi-Processing) is an application programming interface (API) that support ...
 - 页面瀑布流布局的实现 javascript+css
			
先看所谓的瀑布流布局 在不使用瀑布流布局的情况下,当页面要显示不同高度的图片时,会如下面显示 下面的元素总是和最靠近它的元素对齐. 为了使元素能够在我们想要的位置上显示,我们使用绝对定位. 说一下大体 ...
 - jq窗口类小问题
			
if ($(window).height() + $(window).scrollTop() >= $(document.body).height() - options.marginBotto ...
 - correctly handle PNG transparency in Win IE 5.5 & 6.
			
function correctPNG() // correctly handle PNG transparency in Win IE 5.5 & 6. { var arVersion = ...
 - C#委托初探
			
委托是一种定义方法签名的类型,可以与具有兼容签名的任何方法关联.您可以通过委托调用其中已添加的方法列表.委托用于将方法作为参数传递给其他方法.事件处理程序就是通过委托调用的方法.您可以创建一个自定义方 ...
 - lifecycle of opensource products--x86-64
			
x86是指intel的开发的一种32位指令集,从386开始时代开始的,一直沿用至今,是一种cisc指令集,所有intel早期的cpu,amd早期的cpu都支持这种指令集,ntel官方文档里面称为“IA ...
 - Mars 是微信官方的终端基础组件,是一个使用 C++ 编写的业平台性无关的基础组件
			
http://www.oschina.net/p/wechat-mars http://www.oschina.net/news/80453/wewechat-open-source-plan
 - 【Android测试】【随笔】与 “58同城” 测试开发交流
			
◆版权声明:本文出自胖喵~的博客,转载必须注明出处. 转载请注明出处:http://www.cnblogs.com/by-dream/p/5384698.html 初衷 一直都有一个这样的想法: 虽然 ...
 - IAdaptable和IAdaptableFactory(转)
			
先记在这里,回头研究下. 原文:http://blog.csdn.net/mini_snow/article/details/3877379 1. 简介和简单的实现 IAdapteable实际上在Ec ...
 - gulp-less插件之less文件编译成css
			
gulp 是基于node的,所以第一步要确保你已经安装了node环境,具体怎么安装可以到node官网去看一下(https://nodejs.org/en/) 1.全局按钮gulp 打开node窗口输入 ...