社区讨论

WA on test case2求调

P12531 [XJTUPC 2025] Beat Verdict: Precision Strike参与者 2已保存回复 1

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
1 条
当前快照
1 份
快照标识符
@mhj9cod4
此快照首次捕获于
2025/11/03 22:51
4 个月前
此快照最后确认于
2025/11/03 22:51
4 个月前
查看原帖
rt,感觉二分思路是对的,没有样例对拍,找不到错误,求帮忙调代码或提供详细的hack
CPP
#include <bits/stdc++.h>
#define lint long long
using namespace std;
lint T;
lint n, m;
lint ll[31], lr[31];
void init()
{
    for (m = 1; lr[m - 1] < n; ++m) ll[m] = lr[m - 1] + 1, lr[m] = ll[m] * 4;
    --m;
}
int main()
{
    cin >> T;
    while (T--)
    {
        cin >> n;
        init();
        lint l = 1, r = m;
        while (l < r)
        {
            lint mid = (l + r) >> 1;
            cout << "? " << min(n, lr[mid]) << endl;
            cout.flush();
            lint res;
            cin >> res;
            if (res == 0) r = mid;
            else l = mid + 1;
        }
        cout << "! " << min(n, ll[l] * 2) << endl;
        cout.flush();
    }
    return 0;
}

回复

1 条回复,欢迎继续交流。

正在加载回复...