ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

CodeForces - 1205A - Almost Equal(数学规律)

2020-03-06 12:53:10  阅读:308  来源: 互联网

标签:1205A ch const Almost res CodeForces int include define


题目链接:https://vjudge.net/problem/CodeForces-1205A

题目大意:给你一个n,问你能不能用1~2*n这2*n个数组成一个环,在环上每个相邻的n个数的和相差不大于1

(数学不好只能找规律了QAQ)首先两个相邻的n个数和肯定不会相等的,因为两个相邻的n个数中只有一位不同,而数字没有重复的。那么我们

就只能考虑让一个比另一个大1,2*n个元素的环选连续的n个数的和做一个数,那么一共有2*n个情况, 每个元素被计算n次,总和就是(1+2+...+2*n)*n

n个数平均数就是总和除以2*n,也就是((1+2*n)*(2*n)/2)/(2*n) = n*(1+2n)/2,当n是偶数的时候,1+2n是奇数,偶数乘奇数还是偶数,这样所有的2*n个数组成

的数就不能组成相差都大于1的情况了,当n是奇数的时候,就是奇数乘奇数,那么他的平均数就可以一个是偶数(除以2向下取整),一个是奇数(+1除以2向下取整)

所以当n是奇数的时候有解,偶数的时候无解.至于构造吗....就只能打出来符合条件的全排列找规律了......结果是对于下标为1~n,满足如果i是偶数a[i] = 2*i-1, 如果i是奇数,

a[i] = 2*i, 至于i+n~2*n的情况则正好相反. 

#include<set>
#include<map>
#include<list>
#include<stack>
#include<queue>
#include<cmath>
#include<cstdio>
#include<cctype>
#include<string>
#include<vector>
#include<climits>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define endl '\n'
#define rtl rt<<1
#define rtr rt<<1|1
#define lson rt<<1, l, mid
#define rson rt<<1|1, mid+1, r
#define maxx(a, b) (a > b ? a : b)
#define minn(a, b) (a < b ? a : b)
#define zero(a) memset(a, 0, sizeof(a))
#define INF(a) memset(a, 0x3f, sizeof(a))
#define IOS ios::sync_with_stdio(false)
#define _test printf("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n")
using namespace std;
typedef long long ll;
typedef pair<int, int> P;
typedef pair<ll, ll> P2;
const double pi = acos(-1.0);
const double eps = 1e-7;
const ll MOD =  1000000007LL;
const int INF = 0x3f3f3f3f;
const int _NAN = -0x3f3f3f3f;
const double EULC = 0.5772156649015328;
const int NIL = -1;
template<typename T> void read(T &x){
    x = 0;char ch = getchar();ll f = 1;
    while(!isdigit(ch)){if(ch == '-')f*=-1;ch=getchar();}
    while(isdigit(ch)){x = x*10+ch-48;ch=getchar();}x*=f;
}
const int maxn = 2e5+10;
int arr[maxn];
int main(void) {
    int times = 1e2;
    while(times--) {
        ll sum1 = 0, sum2 = 0, sum3 = 0, sum4 = 0;
        int times2 = 1e6;
        while(times2--) {
            ll res = rand()%2;
            if (times2&1) {
                sum1 += 7LL*res;
                sum2 += 3LL*res;
            }
            else {
                sum1 += 3LL*res;
                sum2 += 7LL*res;
            }
            sum3 += 5LL*res;
            sum4 += 5LL*res;
        }
        cout << sum1 << ' ' << sum2 << ' ' << sum3 << ' ' << sum4 << endl;
    }
    return 0;
}

 

标签:1205A,ch,const,Almost,res,CodeForces,int,include,define
来源: https://www.cnblogs.com/shuitiangong/p/12425932.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有