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;
}

慢慢加油。

相关推荐
xiaoye-duck4 小时前
吃透 C++ STL list:从基础使用到特性对比,解锁链表容器高效用法
c++·算法·stl
松☆4 小时前
CANN与大模型推理:在边缘端高效运行7B参数语言模型的实践指南
人工智能·算法·语言模型
java干货4 小时前
为什么 “File 10“ 排在 “File 2“ 前面?解决文件名排序的终极算法:自然排序
开发语言·python·算法
皮皮哎哟4 小时前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
程序员清洒4 小时前
CANN模型剪枝:从敏感度感知到硬件稀疏加速的全链路压缩实战
算法·机器学习·剪枝
vortex55 小时前
几种 dump hash 方式对比分析
算法·哈希算法
Wei&Yan6 小时前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
团子的二进制世界6 小时前
G1垃圾收集器是如何工作的?
java·jvm·算法
吃杠碰小鸡6 小时前
高中数学-数列-导数证明
前端·数学·算法
故事不长丨6 小时前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#