cf Codeforces Round 1062 (Div. 4) Editorial的一些反思

对于A

python 复制代码
T = int(input())
for _  in range(T):
    a,b,c,d = map(int, input().split())
    if a == b ==c == d:
        print("YES")
    else:
        print("NO")

难度在于读英语

对于B

python 复制代码
q = int(input())
from collections import Counter
for _  in range(q):
    t  = int(input())
    s,t = input().split()
    if Counter(s) == Counter(t):
        print("YES")
    else:
        print("NO")

对于C

python 复制代码
T = int(input())
for _ in range(T):
    n  = int(input())
    lst = list(map(int, input().split()))
    ou = any(i%2 == 0 for i in lst)
    ji = any(i%2 == 1 for i in lst)
    if ji and ou:
        print(*sorted(lst))
    else:
        print(*lst)

注意到一旦可以交换 ,那么可以任意交换,否则只能保持原来顺序。

对于D

python 复制代码
# find = []
# zhi = [0 for _  in range(10**8+1)]
# for i in range(2,10**7 +1):
#     if not zhi[i]:
#         find.append(i)
#
#         for j in range(i*i,10**7 +1,i):
#             zhi[j] = 1
# # print(find[:10])
import math
# print(len(find))
t = int(input())
for i in range(t):
    n  = int(input())
    lst = list(map(int, input().split()))
    j = 2
    while True :
        r = False
        for i in range(n):
            if math.gcd(j,lst[i])  == 1:
                print(j)
                r = True
                break
        else:
            j += 1
        if r:
            break

这题难度在于对复杂度的估计,因为要存在一个数没有该质因子,那么这个质因子必然小于等于

通过打表可得

python 复制代码
find = []
zhi = [0 for _  in range(10**7+1)]
for i in range(2,10**7 +1):
    if not zhi[i]:
        find.append(i)

        for j in range(i*i,10**7 +1,i):
            zhi[j] = 1
# print(find[:10])
mul = 1
has  = []
for i in range(2,10**7 +1):
    if  zhi[i]:
        mul*=i
        has.append(i)
        if mul >= 10**18:
            break
print(has)

这个值是26,所以放心地暴力扫就行。

对于E

最大最小想二分,设置前后两个0-mid,x +mid的哨兵,让放置在中间集中。

python 复制代码
t = int(input())
for _  in range(t):
    n,k,x = map(int,input().split())
    lst = list(map(int,input().split()))
    lst.sort()
    def check(mid):
        ls  = [-mid] +lst[:] +[x +mid]
        tmp  = 0
        for i in range(1,n +2):
            tmp += max(0,(ls[i] - mid) - (ls[i-1] +mid ) +1)
        return tmp >= k
    l = -1
    r = x +1
    while l + 1 <r:
        m = (l +r)>>1
        if check(m):
            l = m
        else:
            r = m
    cnt = 0
    ls = [-l] +lst[:] +[x +l]
    res = []
    for i in range(1,n +2):
        for j in range(ls[i-1] +l,ls[i] - l  +1 ):
            res.append(j)
    print(*res[:k])
cpp 复制代码
#include <bits/stdc++.h> 
using namespace std;

// int main() {
//     ios::sync_with_stdio(false);
//     cin.tie(nullptr);
//     cout.tie(nullptr);
//     int t;
//     cin >> t;
int main(){
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int t;
    cin>>t;
    // while (t--) {
    //     int n, k, x;
    //     cin >> n >> k >> x;
    //     vector<int> a(n);
    //     for (int &i : a) cin >> i;
    //     a.push_back(-1e9);
    //     a.push_back(1e9);
    //     n += 2;
    while(t--){
        int n,k,x;
        cin>>n>>k>>x;
        vector<int> a(n);
        for (int &i:a) cin>>i;
        a.push_back(-1e9);
        a.push_back(1e9);
        n += 2;
        // sort(a.begin(), a.end());
        // int l = 0, r = x + 1;
        sort(a.begin(),a.end());
        int l = 0,r = x + 1;

        // while (l + 1 < r) {
        //     int m = (l + r) >> 1, f = 0;
        //     a[0] = - m, a[n - 1] = x + m;
        //     for (int i = 1; i < n; ++i) f += max(0, (a[i] - m) - (a[i - 1] + m) + 1);
        //     if (f >= k) l = m;
        //     else r = m;
        // }
        while ( l  + 1 < r){
            int m = ( l + r)>>1,f = 0;
            a[0] = -m ,a[n-1] = x + m;
            for (int i = 1;i < n;i ++){
                f += max(0,(a[i] - m) - (a[i-1] + m) + 1);
            }
            if (f >=k) l = m;
            else r = m;
        }
        // a[0] = - l, a[n - 1] = x + l;
        // int j = 0;
        // for (int i = 1; i < n; i++)
    	// 	for (j = max(j, a[i - 1] + l); j <= min((a[i] - l), x) && k; j++)
    	// 		cout << j << ' ', k--;
    	// cout << '\n';
        a[0] = -l,a[n-1] = x + l;
        int j = 0;
        for (int i = 1; i < n; i++) {
            for (j = max(j, a[i-1] + l); j <= min((a[i]-l), x) && k; j++) {
                cout << j << ' ';
                k--;
            }
        }
        cout << '\n';
    }
    return 0;
}

慢慢加油。

相关推荐
2401_885665197 小时前
从零搭建卷积神经网络:基于PyTorch实现MNIST手写数字分类
pytorch·python·神经网络·算法·机器学习·分类·cnn
bIo7lyA8v7 小时前
算法优化的多层缓存映射与访问调度模型的技术8
算法
dongf20197 小时前
R语言朴素贝叶斯算法---iris数据集
开发语言·算法·数据分析·r语言
小O的算法实验室7 小时前
2025年KBS,基于强化学习离散状态转移算法+复杂约束下多无人机任务分配
算法
weixin_307779137 小时前
从“大海捞针”到“主动推理”:AI如何重塑云原生故障诊断的根因链
开发语言·人工智能·算法·自动化·原型模式
京东云开发者8 小时前
一键调用!京东云率先上线MiniMax M3
算法
papership8 小时前
入门级-数据结构-2、简单树:二叉树的遍历(前序、中序、后序)
数据结构·算法
WWW65268 小时前
代码随想录 打卡第五十四天
数据结构·c++·算法
happymaker06268 小时前
LeetCodeHot100——15.三数之和
数据结构·算法
墨白曦煜8 小时前
算法实战笔记:空间换时间的黑魔法——单调栈全景解析(十一)
java·笔记·算法