博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Vacant Seat(Atcoder-C-交互式题目)
阅读量:6226 次
发布时间:2019-06-21

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

C - Vacant Seat


Time limit : 2sec / Memory limit : 256MB

Score : 500 points

Problem Statement

This is an interactive task.

Let N be an odd number at least 3.

There are N seats arranged in a circle. The seats are numbered 0 through N−1. For each i (0≤iN−2), Seat i and Seat i+1 are adjacent. Also, Seat N−1 and Seat 0 are adjacent.

Each seat is either vacant, or oppupied by a man or a woman. However, no two adjacent seats are occupied by two people of the same sex. It can be shown that there is at least one empty seat where N is an odd number at least 3.

You are given N, but the states of the seats are not given. Your objective is to correctly guess the ID number of any one of the empty seats. To do so, you can repeatedly send the following query:

  • Choose an integer i (0≤iN−1). If Seat i is empty, the problem is solved. Otherwise, you are notified of the sex of the person in Seat i.

Guess the ID number of an empty seat by sending at most 20 queries.

Constraints

  • N is an odd number.
  • 3≤N≤99 999

Input and Output

First, N is given from Standard Input in the following format:

N

Then, you should send queries. A query should be printed to Standart Output in the following format. Print a newline at the end.

i

The response to the query is given from Standard Input in the following format:

s

Here, s is VacantMale or Female. Each of these means that Seat i is empty, occupied by a man and occupied by a woman, respectively.

Notice

  • Flush Standard Output each time you print something. Failure to do so may result in TLE.
  • Immediately terminate the program when s is Vacant. Otherwise, the verdict is indeterminate.
  • The verdict is indeterminate if more than 20 queries or ill-formatted queries are sent.

Sample Input / Output 1

In this sample, N=3, and Seat 012 are occupied by a man, occupied by a woman and vacant, respectively.

 

Input Output
3  
  0
Male  
  1
Female  
  2
Vacant  

 

 
题意:给你大于等于3的奇数个座位,编号0到N-1,座位情况为空,男,女,其中同性不相邻,至少存在一个空座位,然后你询问一个座位编号,它告诉你现在那个地方是不是空,时空就结束,如果不是就告诉你这个地方的人的性别。要在20次查询以内得出结果!所以必然需要二分!
分析:这是第一次看到交互式题目,真的是看的我很懵逼!觉得很有必要写个博客!交互式,和我们原来做题目的模式是刚好相反的!像题目中给出的案例:输入N以后,输出0,然后我们输入Male,代表0号位置上面坐的男性,下面同样!但是以往我们做的非交互题目都是输入座位编号,然后电脑输出座位的信息!
(注意:这一所谓的性别相同的不能相邻是说中间假设存在空座位的两个性别相同的人之间是相邻的!或者直接相邻!
举个例子:5和7
N=5时,假设0位置为男性,mid=2,如果2号位置与0号位置同性别(假设为男),则一号位置必为女,所以去另外一边查找,left=mid;在left和mid位置同性别的情况下,只要mid-left为偶数就意味着中间不存在空座位;如果left与mid位置性别不同,即本例中的0号和2号位置的性别不同,那么他们中间必然为空;
N=7时,同上假设,mid=3,如果0号和3号位置同性别,就意味着中间两个必然有一个为空,所以right=mid,如果性别不同就意味着中间必然是两种性别交替出现,必然不存在空座位,所以此时left=mid,要注意此时的性别也要换成mid位置的性别。可以画图认真体会!
AC代码:
 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define N 15using namespace std;typedef long long ll;char s[N];int main(){ ios::sync_with_stdio(false); int n,left,right,mid; int M1,M2;//用于标记性别 cin>>n; cout << "0" << endl; cin>>s; if (s[0]=='V') return 0; if (s[0]=='M') M1=1; else M1=0; left=0,right=n; while (left
>s; if (s[0]=='V') return 0; if (s[0]=='M') M2=1; else M2=0; int t=(mid-left); if (t%2==0) { if (M1==M2) left=mid; else right=mid; } else { if (M1==M2) right=mid; else left=mid,M1=M2; } } cout << flush; return 0;}

 

 
 
 
 
 
 
 
 
 

转载于:https://www.cnblogs.com/lisijie/p/8411991.html

你可能感兴趣的文章
php操作mysql与sqlite类
查看>>
Bitmap压缩到指定尺寸大小,获取圆角、圆形图片
查看>>
解决:模态框中使用select2下拉选项无法搜索
查看>>
LeetCode OJ:Min Stack(最小栈问题)
查看>>
什么是FPGA,PAL,EPLD?
查看>>
OO第一次博客作业
查看>>
计算机发展史简述
查看>>
wpf 遍历控件及其值
查看>>
Unity5.6.4f1 配置WebGL教程
查看>>
linux -硬盘分区
查看>>
Struts1防止重复提交
查看>>
JS控制滚动条的位置
查看>>
来自我的破船大大的博客,记录他的iOS成长之路,与君同勉!
查看>>
GridView 编辑、删除 、分页
查看>>
[洛谷P2742]【模板】二维凸包([USACO5.1]圈奶牛Fencing the Cows)
查看>>
C/C++动态二维数组的内存分配和释放
查看>>
HTC G7 官方ROM卡刷包(国行、台版、港版、印度、亚太版、欧版)
查看>>
jQuery笔记(五)jQuery表单验证
查看>>
编程助手JavaScript学习库-面向对象编程笔记
查看>>
聪明的数据结构和笨拙的逻辑代码
查看>>