第 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;
}
相关推荐
㓗冽20 分钟前
60题之内难题分析
开发语言·c++·算法
大江东去浪淘尽千古风流人物21 分钟前
【VLN】VLN仿真与训练三要素 Dataset,Simulators,Benchmarks(2)
深度学习·算法·机器人·概率论·slam
铉铉这波能秀1 小时前
LeetCode Hot100数据结构背景知识之字典(Dictionary)Python2026新版
数据结构·python·算法·leetcode·字典·dictionary
蜡笔小马1 小时前
10.Boost.Geometry R-tree 空间索引详解
开发语言·c++·算法·r-tree
唐梓航-求职中1 小时前
编程-技术-算法-leetcode-288. 单词的唯一缩写
算法·leetcode·c#
仟濹1 小时前
【算法打卡day3 | 2026-02-08 周日 | 算法: BFS】3_卡码网99_计数孤岛_BFS | 4_卡码网100_最大岛屿的面积DFS
算法·深度优先·宽度优先
Ll13045252981 小时前
Leetcode二叉树part4
算法·leetcode·职场和发展
颜酱1 小时前
二叉树遍历思维实战
javascript·后端·算法
宝贝儿好1 小时前
第二章: 图像处理基本操作
算法
小陈phd2 小时前
多模态大模型学习笔记(二)——机器学习十大经典算法:一张表看懂分类 / 回归 / 聚类 / 降维
学习·算法·机器学习