Codeforces Round 865 (Div. 2) (A~C)

文章包含了三个编程挑战的解决方案。A.IanVisitsMary问题中,给出了从(0,0)到(a,b)的路径规划策略。GridReconstruction问题涉及在网格上构造序列,使得最小值最大化。IanandArraySorting问题讨论了数组排序的条件判断。每个问题都提供了C++代码实现。
摘要由CSDN通过智能技术生成

A. Ian Visits Mary

分析

从(0,0)出发,最终到达(a,b),最多走两次,每次走的时候,起点终点的连线上不能出现整数坐标(除开起点和终点),如果有a,b中有一个为1的话走一步即可,否则先走到(1,b-1),再走到(a,b)。

代码实现

#include<bits/stdc++.h>

using namespace std;

typedef long long ll;
typedef pair<int,int> pii;
const int N = 100010,mod = 1e9+7;
int n,m;

void solve()
{
    cin >> n >> m;
    if(n == 1 || m == 1) 
    {
        cout << 1 << '\n';
        cout << n << ' ' << m << '\n';
        return ;
    }
    cout << 2 << '\n';
    cout << 1 << ' ' << m - 1 << '\n';
    cout << n << ' ' << m << '\n';
}

int main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int tt;
    cin >> tt;
    while(tt--)
    {
        solve();
    }
    return 0;
}

B. Grid Reconstruction

分析

这题我通过看样例对其猜测,(1,1)和(2,n)一定放最大的2*n,2*n-1,接下来如何使最小值最大。只能向右和下移动的话,那么其实方格的数字实际会进行的操作就是如下(当n=4时

+-+-
-+-+

贪一下,小的数放在要减去的位置,大的数放在加上的位置,证明我不太会。

代码实现

#include<bits/stdc++.h>

using namespace std;

typedef long long ll;
typedef pair<int,int> pii;
const int N = 100010,mod = 1e9+7;
int n,m;
int a[3][N];

void solve()
{
    int n;
    cin >> n;
    int x = 1, y = 2, xx = 2 * n - 3, yy = 2 * n - 2;
    a[1][1] = n * 2, a[2][n] = n * 2 - 1;
    for(int i = 2;i <= n; i++)
    {
        if(i % 2)
        {
            a[1][i] = xx;
            a[2][i - 1] = yy;
            xx -= 2, yy -= 2;
        }
        else 
        {
            a[1][i] = x;
            a[2][i - 1] = y;
            x += 2, y += 2;
        }
    }
    for(int i = 1;i <= 2; i++)
    {
        for(int j = 1;j <= n; j++)
            cout << a[i][j] << ' ';
        cout << '\n';
    }
}

int main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int tt;
    cin >> tt;
    while(tt--)
    {
        solve();
    }
    return 0;
}

C. Ian and Array Sorting

这题搞了我几个小时,感觉有时候就是想不到,要么就想到一点点。

分析

a1-1,a2-1,a2+1,a3+1这里可以看出a1-1,a3+1,那么奇偶性相同的可以互相传递,我们可以只用看最后两位数,去进行比较a[n-1] <= a[n-2]输出YES,当n为奇数时要思考一下,尽管a[n-1]>a[n],但可以通过值传递,a[1]=-a[n-1]。例如利用我们找到的特性转变[0,0,0,4,1],还可以变[-4,0,0,0,1]。

代码实现

#include<bits/stdc++.h>

using namespace std;

typedef long long ll;
typedef pair<int,int> pii;
const int N = 100010,mod = 1e9+7;
int n,m;

void solve()
{
    int n;
    cin >> n;
    vector<ll> a(n + 10);
    for(int i = 1;i <= n; i++) cin >> a[i];
    if(n % 2) 
    {
        cout << "YES\n";
        return ;
    }
    ll sum = 0;
    for(int i = 1;i <= n; i++) 
        if(i & 1) sum -= a[i];
        else sum += a[i];
    if(sum >= 0) cout << "YES\n";
    else cout << "NO\n";
}

int main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int tt;
    cin >> tt;
    while(tt--)
    {
        solve();
    }
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值