第 34 场 蓝桥·算法入门赛·百校联赛

https://www.lanqiao.cn/oj-contest/newbie-34/

目录

总结

[1. 2026全年天数](#1. 2026全年天数)

[2. 年货搬运](#2. 年货搬运)

[3. 采购沙琪玛](#3. 采购沙琪玛)

[4. 分配年货](#4. 分配年货)

[5. 年货竞猜](#5. 年货竞猜)

[6. 刮刮乐卡](#6. 刮刮乐卡)


总结

第3题:取上界除法

第5题:计算时将n*(n+1)/2拆成两部分可以将一次T的时间复杂度从n降低到根号n

第6题:s.erase()用法

1. 2026全年天数

cpp 复制代码
#include <iostream>
using namespace std;
int main()
{
    cout << 365;
    return 0;
}

2. 年货搬运

cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main()
{
    int n, k;
    cin >> n >> k;
    vector<int> s(n);
    for (int i = 0; i < n; i++)
    {
        cin >> s[i];
        if (s[i] > k)
        {
            cout << -1;
            return 0;
        }
    }
    int ans = 0;
    sort(s.begin(), s.end());
    int left = 0;
    int right = n - 1;
    while (left <= right)
    {
        if (s[left] + s[right] <= k)
        {
            ans++;
            left++;
            right--;
        }
        else
        {
            ans++;
            right--;
        }
    }
    cout << ans;
    return 0;
}

3. 采购沙琪玛

cpp 复制代码
#include <iostream>
using namespace std;
int main()
{
    int n;
    cin >> n;
    int ans = 0x3f3f3f3f;
    int Amax = (n + 99) / 100;
    ans = min(Amax * 100, ans);
    int A = n / 100;
    n = max(0, n - A * 100);
    int Bmax = (n + 19) / 20;
    ans = min(A * 100 + Bmax * 30, ans);
    int B = n / 20;
    n = max(0, n - B * 20);
    int C = n;
    ans = min(C * 2 + B * 30 + A * 100, ans);
    cout << ans;
    return 0;
}

4. 分配年货

cpp 复制代码
#include <iostream>
using namespace std;
void solve()
{
    int n;
    cin >> n;
    if (n <= 2)
    {
        cout << -1 << endl;
        return;
    }
    cout << n / 3 << endl;
}
int main()
{
    int t;
    cin >> t;
    while (t--)
    {
        solve();
    }
    return 0;
}

5. 年货竞猜

计算时将n*(n+1)/2拆成两部分可以将一次T的时间复杂度从n降低到根号n

cpp 复制代码
#include <iostream>
using namespace std;
#define int long long
void solve()
{
    int n;
    cin >> n;
    int a, b;
    if (n % 2 == 0)
    {
        a = n / 2;
        b = n + 1;
    }
    else
    {
        a = n;
        b = (n + 1) / 2;
    }
    int cntA = 0, cntB = 0;
    for (int i = 1; i * i <= a; i++)
    {
        if (a % i == 0)
        {
            cntA += 2;
            if (i * i == a)
            {
                cntA--;
            }
        }
    }
    for (int i = 1; i * i <= b; i++)
    {
        if (b % i == 0)
        {
            cntB += 2;
            if (i * i == b)
            {
                cntB--;
            }
        }
    }
    int ans = cntA * cntB;
    cout << ans << endl;
}
signed main()
{
    int t;
    cin >> t;
    while (t--)
    {
        solve();
    }
    return 0;
}

6. 刮刮乐卡

cpp 复制代码
#include <iostream>
using namespace std;
int main()
{
    string s;
    cin >> s;
    for (int i = (int)s.size() - 2; i >= 1; i--)
    {
        if (s[i - 1] == 'L' && s[i] == 'Q' && s[i + 1] == 'Q')
        {
            s.erase(i - 1, 2);
        }
    }
    cout << s << endl;
    return 0;
}
相关推荐
ASD125478acx7 小时前
超声心动图心脏自动检测YOLO11-NetBifPN算法实现与优化
算法
无限进步_8 小时前
【C语言&数据结构】对称二叉树:镜像世界的递归探索
c语言·开发语言·数据结构·c++·git·算法·visual studio
星辞树8 小时前
揭秘阿里 DIN:当深度学习遇上“千物千面”
算法
刘立军8 小时前
如何选择FAISS的索引类型
人工智能·算法·架构
小芒果_018 小时前
整理归并排序
c++·算法·排序算法·信息学奥赛
牛三金8 小时前
匿踪查询沿革-Private Information Retrieval(PIR)
算法·安全
德育处主任8 小时前
『NAS』在群晖部署一个文件加密工具-hat.sh
前端·算法·docker
星辞树8 小时前
从 L1/L2 到 Dropout:深度解析正则化,为何推荐系统“只能练一次”?
算法
玖剹9 小时前
队列+宽搜(bfs)
数据结构·c++·算法·leetcode·宽度优先