loj #6.Guess Number

原题链接:https://loj.ac/problem/6
题目描述:


Guess Number

内存限制:256 MiB
时间限制:1000 ms
题目类型:交互

题目描述

这是一个交互题的模板。
系统会随机生成 n 个数 Ai,你需要猜测出这 n 个数的值。暴力枚举 / 二分 / 随机猜测等方法都可以解决这个问题,但得分将依猜测次数而定。

交互方式
使用 C++ 与 C++11 的选手将可以利用系统给出的交互库来进行交互。

使用其他语言的选手也不必担心,我们提供了一个友好的交互接口,你将能够轻而易举地通过标准输入 / 输出来进行交互。

不使用交互库
为了更清晰地演示交互题的使用方法,我们设计了三种操作:

  1. get_num:获取需要猜测的数字数量 n 。本操作不包含参数。
  2. guess:猜测某个数字。本操作包含 2 个参数:需要猜测的数字的序号(从 0 开始)以及猜测值。当你猜测的值小于实际值时,返回值为 -1;当你猜测的值大于实际值时,返回值为 1;当恰好猜对时,返回值为 0。
  3. submit:提交猜测结果。本操作包含 n 个参数,即 n 个数的猜测结果。本操作没有返回值。
    当你想要进行某个操作时,请向标准输出流中写入如下格式的字符串:
    <操作名称> <操作参数 1> <操作参数 2> ... <操作参数 n>
    你必须在请求后追加换行符;多余的空白字符将被自动忽略。

在收到用户程序发送的请求后,交互器会向用户程序的标准输入流中发送返回值。你只需在你的程序中使用通常的办法读入这个值,就好像是从控制台或文件中读取内容一样。交互器将在发送返回值后再附加一个换行符 \n,以便于用户程序读入。本题目的操作返回值都是数字,因此直接读入数字即可。

请注意,很多语言的输入 / 输出库都会带有缓存,请在写入操作请求后手动刷新缓存,以确保请求顺利递送。

C++ 语言可以这样刷新缓存(std::endl 会自动刷新缓存):

std::cout << std::flush;
// 或 std::cout << value << std::endl;
提交猜测结果后,即可结束程序。交互器退出时,如果用户程序还在运行,就会被立即终止,但不会引发超时错误。

使用交互库
对于 C++ 与 C++11 选手,我们提供交互库 interaction.h,你将可以通过题目上方的「附加文件」下载到这个交互库。正式比赛时交互库也将是公开的。

当然,你可以选择不使用交互库,自己通过标准输入输出来通信。

C++ 与 C++11 的 interaction.h 将包含三个原型如下的函数:

int get_num();
int guess(int index, int x);
void submit(const std::vector<int> &resultv);

参数的意义及返回值请参见上面的描述。

附注 1 文件说明
「附加文件」中的 interaction.h 为供用户调用的交互库;interactor.cpp 为交互器。

附注 2 C 与 C++ #include 说明
#include <file> 表示在标准库及默认搜索目录中寻找将要 include 的文件;#include "file" 表示先在当前目录中搜索文件,然后再到默认搜索目录中搜寻。

在提交交互题时,请使用 #include "interaction.h"

输入格式

输入文件是供交互器使用的;一般用户无需在意这里的内容,只需关心如何与交互器交互即可。 第一行一个正整数 n ,表示有 n 个数,第二行 n 个正整数表示要猜的序列。

样例

样例输入

5
1 2 3 4 5

数据范围与提示

数量 1≤n≤100;
要猜测的数字 0≤Ai≤1000000
请尽量保证你的猜测次数在 1000n 之内,对于每个测试点,设你的猜测次数为 x ,则你的得分为 max(min(100,(950−(x/n−100))/950×100),0)
每次猜测均为 I / O 操作,消耗时间较多,如果猜测次数过多将导致超时。


题目大意:使用高效率的方式猜测数据
题目思路:使用二分法

#include <stdio.h>
#include <stdlib.h>

#define MAX 1000000

int guess(int i)
{
    int l=0,r=MAX,m;
    int status;
    while (l < r)
    {
        m = (l+r) >> 1;
        printf("guess %d %d\n", i, m);
        fflush(stdout);
        scanf("%d", &status);
        switch (status)
        {
            case -1:
                l = m + 1;
                break;
            case 1:
                r = m - 1;
                break;
            case 0:
                return m;
        }
    }
    return l;
}

int main()
{
    int n, a[100];
    printf("get_num\n");
    fflush(stdout);
    scanf("%d", &n);
    for (int i=0; i<n; i++)
        a[i] = guess(i);
    printf("submit");
    for (int i=0; i<n; i++)
        printf(" %d", a[i]);
    printf("\n");
    fflush(stdout);
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,366评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,521评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,689评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,925评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,942评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,727评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,447评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,349评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,820评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,990评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,127评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,812评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,471评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,017评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,142评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,388评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,066评论 2 355

推荐阅读更多精彩内容