首页 > 其他分享 >Good Bye 2022: 2023 is NEAR 补C

Good Bye 2022: 2023 is NEAR 补C

时间:2023-01-04 20:11:19浏览次数:57  
标签:Good int LONG NEAR solve long 余数 Bye define

A. Koxia and Whiteboards

题意:

给定两个长度为 n 的数组,进行 m 次交换,第 i 次选择 a 中的一个数与 bi 交换,计算交换后 n 个数的和最大值

分析:

堆维护最小值进行交换

#include <bits/stdc++.h>
using namespace std;
#define mst(x, y) memset(x, y, sizeof x)
#define endl '\n'
#define INF LONG_LONG_MAX
#define x first
#define y second
#define int long long
#define Lson u << 1, l, mid
#define Rson u << 1 | 1, mid + 1, r
#define FAST ios::sync_with_stdio(false), cin.tie(0), cout.tie(0)
const int N = 200010, MOD = 1e9 + 7;
const double EPS = 1e-6;
typedef pair<int, int> PII;
typedef unordered_map<int, int> Ump;
int T;
int n, m;
int a[N], b[N];
int sum;
bool cmp(int a, int b)
{
    return a > b;
}
void solve()
{
    priority_queue<int, vector<int>, greater<int>> q;
    sum = 0;
    cin >> n >> m;
    for (int i = 1, x; i <= n; i++)
    {
        cin >> x;
        sum += x;
        q.push(x);
    }

    for (int i = 1; i <= m; i++)
        cin >> b[i];

    int pos = 1;
    while (pos <= m)
    {
        int t = q.top();
        q.pop();
        sum -= t;
        sum += b[pos];
        q.push(b[pos]);
        pos++;
    }
    cout << sum << endl;
}
signed main()
{
    FAST;
    cin >> T;
    while (T--)
        solve();
    return 0;
}

B. Koxia and Permutation

题意:

\[构造一种排列,实现连续的 k 个数中ci=max(pi,…,pi+k−1)+min(pi,…,pi+k−1)的最大值最小 \]

分析:

对每一组,考虑最大数与最小数的中和,这样就能保证每一组的价值尽可能的小

#include <bits/stdc++.h>
#include <bits/extc++.h>
using namespace std;
using namespace __gnu_pbds;
#define mst(x, y) memset(x, y, sizeof x)
#define endl '\n'
#define INF LONG_LONG_MAX
#define x first
#define y second
#define int long long
#define Lson u << 1, l, mid
#define Rson u << 1 | 1, mid + 1, r
#define FAST ios::sync_with_stdio(false), cin.tie(0), cout.tie(0)
const int N = 200010, MOD = 1e9 + 7;
const double EPS = 1e-6;
typedef pair<int, int> PII;
typedef unordered_map<int, int> Ump;
int T;
int n, k;
void solve()
{
    int idx = 0, pos = 1;
    cin >> n >> k;
    for (int i = n; i >= pos; i--)
    {
        cout << i << " ";
        idx++;
        if (idx == k - 1)
        {
            idx = 0;
            if (i > pos)
            {
                cout << pos << " ";
                pos++;
            }
        }
    }
    cout << endl;
}
signed main()
{
    FAST;
    cin >> T;
    while (T--)
        solve();
    return 0;
}

C. Koxia and Number Theory

题意:

\[给定一个长度为n的数组,请问是否存在一个数 x ,使得任意两个数满足 gcd(ai + x, aj + x) == 1 \]

分析:

模运算的性质;

  • 首先,如果有两个数相同肯定就不行。
  • 如果某一个质数的余数中,如果每一种余数都有至少两:个的话,这显然是不行的。

为什么每一种余数都有至少两个的话,这显然是不行的呢:
因为此时,余数为 0 的任意两个数的最大公约数肯定不是 1,若取任意的 x,都有可能将至少两个原来余数不是 0 的数变为余数为 0(此时至少有 2 个数的gcd不为 1 ),也就是最大公约数不为 1,自然不行。
题目要求是存在,即找到一个 x 即可,当对一个数的所有小于这个数的所有模数都至少有 2 个时,直接“NO”,其他情况必可以找到一个 x ,使得同模一个数的余数唯一,即"YES"

#include <bits/stdc++.h>
#include <bits/extc++.h>
using namespace std;
using namespace __gnu_pbds;
#define mst(x, y) memset(x, y, sizeof x)
#define endl '\n'
#define INF LONG_LONG_MAX
#define x first
#define y second
#define int long long
#define Lson u << 1, l, mid
#define Rson u << 1 | 1, mid + 1, r
#define FAST ios::sync_with_stdio(false), cin.tie(0), cout.tie(0)
const int N = 200010, MOD = 1e9 + 7;
const double EPS = 1e-6;
typedef pair<int, int> PII;
typedef unordered_map<int, int> Ump;
int T;
int a[] = {2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97};
int n, b[N];
bool f;
map<int, bool> mp;
int cnt[N];
void solve()
{
    mp.clear();
    cin >> n;
    for (int i = 1; i <= n; i++)
    {
        cin >> b[i];
    }
    int f = 0;
    for (int i = 1; i <= n; i++)
    {
        if (mp[b[i]])
        {
            f = 1;
            cout << "NO" << endl;
            break;
        }
        mp[b[i]] = true;
    }
    if (f == 1)
        return;
    int ff = 0;
    for (int i = 0; i < 25; i++)
    {
        mst(cnt, 0);
        for (int j = 1; j <= n; j++)
        {
            cnt[b[j] % a[i]]++;
        }
        f = 0;
        for (int j = 0; j < a[i]; j++)
        {
            if (cnt[j] < 2)
            {
                f = 1;
                break;
            }
        }
        if (f == 0)
        {
            cout << "NO\n";
            ff = 1;
            break;
        }
    }
    if (ff == 0)
    {
        cout << "YES\n";
    }
}
signed main()
{
    FAST;
    cin >> T;
    while (T--)
        solve();
    return 0;
}

标签:Good,int,LONG,NEAR,solve,long,余数,Bye,define
From: https://www.cnblogs.com/Aidan347/p/17022814.html

相关文章

  • @AspectJ support (good)
    AspectJ类型匹配的通配符:*:匹配任何数量字符;..:匹配任何数量字符的重复,如在类型模式中匹配任何数量子包;而在方法参数模式中匹配任何数量参数。+:匹配指定类型的子类型;仅能作为......
  • git/github初级运用自如 (good)
    三.设置用户信息这一步不是很重要,貌似不设置也行,但github官方步骤中有,所以这里也提一下。在git中设置用户名,邮箱$gitconfig--globaluser.name"defnngj"//给自己起个......
  • ELK日志系统:Elasticsearch + Logstash + Kibana 搭建教程 good
     elk中kibna搜索时,如果搜索 包含 单个 双引号 的字符串时:"'/goods"&&"result\":true"  使用双引号包起来作为一个短语搜索"likeGecko"#字段也可以按页面左侧显示......
  • Codeforces Good Bye 2022 CF 1770 F Koxia and Sequence 题解
    题目链接注意题目要求的是所有好序列的所有元素的XOR之和的XOR之和。我一开始以为是所有XOR之和的加法和导致不知道官方题解在讲什么。假设我们枚举一个位置\(1\lei\le......
  • angularJS友好URL实现 good
    nginx部署angularjs时的rewrite问题使用h5+angularjs完成了一个项目此项目在正式环境上使用nginx做webserver此项目的入口在微信/微博分享中由于分享时的项目访问地址中......
  • curl命令常见用法汇总 good
     ​​curl​​是一种命令行工具,作用是发出网络请求,然后得到和提取数据,显示在"标准输出"(stdout)上面。curl是一个强大的命令行工具,它可以通过网络将信息传递给服务器或者从服......
  • Java中动态代理技术生成的类与原始类的区别 (good)
    用动态代理的时候,对它新生成的类长什么样子感到好奇.有幸通过一些资料消除了心里的疑惑.平时工作使用的Spring框架里面有一个AOP(面向切面)的机制,只知道它是把类......
  • Good Bye 2021: 2022 is NEAR D
    D.KeeptheAverageHigh题链又是任何一个任意正整数z,2x+3y=z有整数解。namo对于一个区间和为负数这个区间肯定可以又一些个长度为2长度为3的小区间构成要是我们......
  • Bye2022, Hi2023
    差不多一个多月没怎么出门了,窗外烟花爆竹声不绝于耳,谁也没料到今年的元旦会是这样,就像2020的春节。这一年最大的收获是小瑞瑞出生了,还有很多其他的收获,各方各面的,视野也更......
  • 机器学习技法---(Week1)Linear Support Vector Machine
      技法的课,相对更关注算法,希望1个月内搞掂~课程介绍  共计16周课程,主要内容:哲学上直观的理解、关键理论、核心算法和实际操作的注意点。围绕特征变换,本次课程涉及到以......