每日两题day65

今天你AC了吗?

每日两题day65


一、基础题

题目:P1008 [NOIP 1998 普及组] 三连击 - 洛谷

思路:

暴力遍历每个三位数及其倍数,拆开检查是否是1~9的序列

代码:

cpp 复制代码
#include <bits/stdc++.h>

using i64 = long long;
constexpr int inf = 2147483647;

int main() {
    for (int i = 100; i * 3 <= 999; i++) {
        int j = 4;
        std::set<char> x;
        while (--j) {
            std::string s = std::to_string(j * i);
            for (auto u: s) {
                x.insert(u);
            }
            if (x.size() == 9 && *x.begin() != '0') {
                printf("%d %d %d\n", i, i * 2, i * 3);
            }
        }
    }
    return 0;
}

二、提高题

题目:P1098 [NOIP 2007 提高组] 字符串的展开 - 洛谷

思路:

遍历s,遇到'-'时检查前后是否满足展开条件,再按是否星号->是否数字->是否大小写,最后统一处理是否翻转的顺序分类处理(ps:不保证是最简写法),处理下标(/指针/迭代器)时注意越界问题。

代码:

cpp 复制代码
#include <bits/stdc++.h>

using i64 = long long;
constexpr int inf = 2147483647;

int main() {
    int a, b, c;
    std::string s;
    std::cin >> a >> b >> c >> s;
    std::string r;
    for (int i = 0; i < s.size(); i++) {
        if (s[i] == '-' && i > 0 && s[i - 1] != '-' && i < s.size() - 1 && s[i + 1] != '-') {
            if (s[i + 1] <= s[i - 1] || abs(s[i + 1] - s[i - 1]) > 26) {
                r.push_back(s[i]);
            } else {
                int x = r.size();//记录展开字符串的第一个字符位置
                if (a != 3) {
                    for (int ii = s[i - 1] + 1; ii <= s[i + 1] - 1; ii++) {
                        for (int j = 0; j < b; j++) {
                            r.push_back((char) ii);
                        }
                    }
                    if (a == 2 && s[i - 1] >= 'a' && s[i - 1] <= 'z') {
                        for (int j = x; j < r.size(); j++) {
                            r[j] += 'A' - 'a';
                        }
                    }
                } else {
                    int cnt = s[i + 1] - s[i - 1] - 1;
                    cnt *= b;
                    if (cnt <= 0) cnt = 0;
                    while (cnt--) {
                        r.push_back('*');
                    }
                }
                if (c == 2) {
                    std::reverse(r.begin() + x, r.end());
                }
            }
        } else {
            r.push_back(s[i]);
        }
    }
    std::cout << r;
    return 0;
}
相关推荐
君生我老6 分钟前
C++自写list类
c++
阿猿收手吧!20 分钟前
【C++】异步编程:std::async终极指南
开发语言·c++
数智工坊24 分钟前
【数据结构-树与二叉树】4.6 树与森林的存储-转化-遍历
数据结构
REDcker24 分钟前
gRPC开发者快速入门
服务器·c++·后端·grpc
晚霞的不甘32 分钟前
Flutter for OpenHarmony 可视化教学:A* 寻路算法的交互式演示
人工智能·算法·flutter·架构·开源·音视频
doupoa33 分钟前
内存指针是什么?为什么指针还要有偏移量?
android·c++
望舒51336 分钟前
代码随想录day25,回溯算法part4
java·数据结构·算法·leetcode
独好紫罗兰1 小时前
对python的再认识-基于数据结构进行-a006-元组-拓展
开发语言·数据结构·python
冉佳驹1 小时前
C++ ——— 异常处理的核心机制和智能指针管理
c++·异常捕获·异常继承体与多态·重载抛异常·raii思想·智能指针shared_ptr·weak_ptr指针
C++ 老炮儿的技术栈1 小时前
Qt 编写 TcpClient 程序 详细步骤
c语言·开发语言·数据库·c++·qt·算法