Educational Codeforces Round 156 (Rated for Div. 2) - B+C

B. Fear of the Dark

其实刚开始我想到了需要考虑o点和p点同时包含在a圆或者b圆中的情况;也考虑到了相切的情况

但是后来看题解后发现,在相切的时候,还需要满足o点和p点能够被包含在a圆或者b圆中

cpp 复制代码
#include <math.h>
#include <stdio.h>
#include <cstring>
#include <iostream>
using namespace std;
const int N = 1e6 + 10;
#define de(x) cout << x << " ";
// int n, m, ans;
double px, py, ax, ay, bx, by;
double dis(double x1, double y1, double x2, double y2) {
    return sqrt(1.0 * (x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2));
}
void solve() {
    cin >> px >> py >> ax >> ay >> bx >> by;
    double ao = dis(0, 0, ax, ay);
    double bo = dis(0, 0, bx, by);
    double ap = dis(px, py, ax, ay);
    double bp = dis(px, py, bx, by);
    double ab = dis(ax, ay, bx, by);
    double ans = 1e9;
    ans = min(ans, max(ao, ap));  // 表示o点和p点在a圆中
    ans = min(ans, max(bo, bp));  // 表示o点和p点在b圆中
    // 表示o点和p点分别在a圆或者b圆中,此时还需要满足相切的条件
    ans = min(ans, max(ab / 2, max(ap, bo)));
    ans = min(ans, max(ab / 2, max(ao, bp)));
    printf("%.10lf\n", ans);
}
int main() {
    int T;
    cin >> T;
    while (T--) {
        solve();
    }
    return 0;
}

C. Decreasing String

看了官方题解才写出来,很巧妙

思路见代码注释

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define sf(x) scanf("%d", &x);
#define de(x) cout << x << " ";
#define Pu puts("");
const int N = 2e4 + 9, mod = 1e9 + 7;
// int n, m;
string s;
ll pos;
ll len;
stack<char> q;
void solve() {
    cin >> s >> pos;
    pos--;  // 注意下标是从0开始的
    len = s.size();
    while (!q.empty())
        q.pop();
    bool ok = (pos < len);
    s += '$';  // 很小的ascll码
    for (auto c : s) {
        while (!ok && !q.empty() && q.top() > c) {
            pos -= len;  // 核心,使用线性的复杂度
            // 我们只需要动一个就已经处理了当前长度len下的字符串
            // 而且前面已经在栈中的我们不需要动,因为下一个len-1长度下
            // 需要在栈中已有元素的基础上进行
            len--;
            q.pop();
            if (pos < len)
                ok = true;  // 如果
        }
        q.push(c);
    }
    string tmp = "";
    while (!q.empty())
        tmp += q.top(), q.pop();

    reverse(tmp.begin(), tmp.end());  // 注意这里需要翻转
    // 因为我们得到的字符串是从后往前的

    cout << tmp[pos];
}
int main() {
    int T;
    cin >> T;
    while (T--) {
        solve();
    }
    return 0;
}
相关推荐
陌路205 分钟前
S12 简单排序算法--冒泡 选择 直接插入 希尔排序
数据结构·算法·排序算法
雾岛—听风40 分钟前
P1012 [NOIP 1998 提高组] 拼数
算法
papership1 小时前
【入门级-算法-5、数值处理算法:高精度的乘法】
数据结构·算法
earthzhang20211 小时前
【1039】判断数正负
开发语言·数据结构·c++·算法·青少年编程
谈笑也风生1 小时前
只出现一次的数字 II(一)
数据结构·算法·leetcode
蕓晨1 小时前
auto 自动类型推导以及注意事项
开发语言·c++·算法
mjhcsp2 小时前
C++ 递推与递归:两种算法思想的深度解析与实战
开发语言·c++·算法
_OP_CHEN2 小时前
算法基础篇:(三)基础算法之枚举:暴力美学的艺术,从穷举到高效优化
c++·算法·枚举·算法竞赛·acm竞赛·二进制枚举·普通枚举
m0_748248022 小时前
《详解 C++ Date 类的设计与实现:从运算符重载到功能测试》
java·开发语言·c++·算法
天选之女wow2 小时前
【代码随想录算法训练营——Day61】图论——97.小明逛公园、127.骑士的攻击
算法·图论