Codeforces Round #580 (Div. 2)
这次比上次多A了一道,但做得太慢,rating还是降了。
Problem A Choose Two Numbers
题意:给出两个集合A,B,从A,B中分别选出元素a,b使得a+b既不属于集合A,又不属于集合B
数据范围:1<=集合A,B的大小<=100 1<=a,b<=200
我的做法是直接模拟就好了,复杂度:O(nm(n+m))
题解的做法是分别取集合A,集合B中的最大值a,b就可以了,显然此时的a+b既不属于A,也不属于B
#include <iostream>
#include <cstdio>
using namespace std;
int n,m;
int a[210],b[210];
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)scanf("%d",&a[i]);
scanf("%d",&m);
for(int j=1;j<=m;j++)scanf("%d",&b[j]);
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
int x=a[i]+b[j];
int pd1=0,pd2=0;
for(int ii=1;ii<=n;ii++)
{
if(x==a[ii])
{
pd1=1;break;
}
}
if(pd1==1)continue;
for(int jj=1;jj<=m;jj++)
{
if(x==b[jj])
{
pd2=1;break;
}
}
if(!pd1&&!pd2)
{
printf("%d %d\n",a[i],b[j]);return 0;
}
}
}
return 0;
}
Problem B Make Product Equal One
给出n个数a1,a2,...,an,你可以用一点花费使得a[i]加一或减一,求最小的花费使得a1 *a2 *a3 *... *an=1。
数据范围:1<=n<=1e5 -1e9<=a[i]<=1e9
贪心,从1枚举到n,如果一个数为正,把它变为1,如果为负,变为0,同时记录负数的个数,如果为0,则花费加1,这个0因为可以变成1也可以变成-1,所以可以用来调节正负(只需要一个0就可以调节正负) 统计完以后,如果0的个数为0(即不能调节正负),且负数的个数为奇数,则答案+=2
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cmath>
using namespace std;
int n;
int main()
{
int tot1=0;
scanf("%d",&n);
long long ans=0;
int tot2=0;
for(int i=1;i<=n;i++)
{
int x;scanf("%d",&x);
if(x<0)
{ans+=-1-x;tot1++;}
else
{
if(x==0){tot2++;ans+=1;}
else{ans+=x-1;}
}
}
if(tot1%2==1&&tot2==0)ans+=2;
cout<<ans;
return 0;
}
Problem C Almost Equal
题意:给出一个数字n,由1,2,3,...,2*n按一定顺序组成一个圆环,求出一种顺序使得以下成立:将圆环上的每n个连续数字累加起来得到一个和,将这个和写在黑板上,写完2n个和以后,使得黑板上任意两个和的差小于等于1。
举例:
当n=3的情况:

在左图中,1+4+5=10,4+5+2=11,5+2+3=10,2+3+6=11,3+6+1=10,6+1+4=11
|11-10|<=1,满足题意。
在右图中,1+5+6=12,3+2+4=9, |12-9|>=3,不满足题意
输入:一个正整数n,(1<=n<=100000)
输出:如果没有解决方案,输出“NO”
如果有解决方案,输出“YES”,下一行输出2n个正整数,表示满足题意的任意一种顺序
构造题,这道题一开始我毫无思路,再后来观察发现了一个性质,第i个数和第i+n个数的差一定小于等于1,
然后我用爆搜打了个表找规律
1: YES 1 2
2: NO
3: YES 1 4 5 2 3 6
4: NO
5: YES 1 4 5 8 9 2 3 6 7 10
6: NO
7: YES 1 4 5 8 9 12 13 2 3 6 7 10 11 14
然后规律就很明显了:
偶数输出NO
一个简单的证明是:
2n个数字的和为n*(2n+1),如果n为偶数,那么和为偶数,能够被分成两个相等的和x
又因为第i个数和第i+n个数的差一定为1,则必定存在x+1和x-1两种和
奇数输出YES,并且奇数的排列可以从上一个奇数转化过来
比如 3:1 4 5 2 3 6
由第i个数和第i+n个数的差一定小于等于1
那么我们把3这个式子转化一下:0 1 0 1 0 1
5就是:0 1 0 1 0 1 0 1 0 1
所以就很容易构造出答案了,时间复杂度:O(n*2)
for(int i=1;i<=n;i++)//输出前n个数
{
if(i%2==1)//i是奇数
{
printf("%d ",i*2-1);
}
if(i%2==0)//i是偶数
{
printf("%d ",i*2);
}
}
for(int i=1;i<=n;i++)//输出第n+1到第2*n个数
{
if(i%2==1)
{
printf("%d ",i*2);
}
if(i%2==0)
{
printf("%d ",i*2-1);
}
}
Codeforces Round #580 (Div. 2)的更多相关文章
- Codeforces Round #580 (Div. 1)
Codeforces Round #580 (Div. 1) https://codeforces.com/contest/1205 A. Almost Equal 随便构造一下吧...太水了不说了, ...
- Codeforces Round #580 (Div. 1) A-E
Contest Page A Tag:构造 将$a_i$看做一个无穷数列,$i > 2n$时$a_i = a_{i - 2n}$.设$sgn_i = \sum\limits_{j=i+1}^{i ...
- Codeforces Round #580 (Div. 2)D(思维,Floyd暴力最小环)
#define HAVE_STRUCT_TIMESPEC#include<bits/stdc++.h>using namespace std;const int maxn=300;cons ...
- Codeforces Round #580 (Div. 2)-D. Shortest Cycle(思维建图+dfs找最小环)
You are given nn integer numbers a1,a2,…,ana1,a2,…,an. Consider graph on nn nodes, in which nodes ii ...
- Codeforces Round #366 (Div. 2) ABC
Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...
- Codeforces Round #354 (Div. 2) ABCD
Codeforces Round #354 (Div. 2) Problems # Name A Nicholas and Permutation standard input/out ...
- Codeforces Round #368 (Div. 2)
直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- Codeforces Round #279 (Div. 2) ABCDE
Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems # Name A Team Olympiad standard input/outpu ...
随机推荐
- Python可修改和不可修改类型变量(mutuable and immutuable)
通俗的讲,可修改可以理解为可以在数据所在内存地址直接修改,而不可修改则意味着一旦修改便是创建新的数据对象,而不是在原来的对象内存地址修改 1,Mutuable object [sourcecode l ...
- MyBatis 源码篇-插件模块
本章主要描述 MyBatis 插件模块的原理,从以下两点出发: MyBatis 是如何加载插件配置的? MyBatis 是如何实现用户使用自定义拦截器对 SQL 语句执行过程中的某一点进行拦截的? 示 ...
- Lua虚拟机中的数据结构与栈
Lua虚拟机中的数据结构与栈 来源 https://blog.csdn.net/zry112233/article/details/80828327 由上一篇文章可知解释器分析Lua文件之后生成Pro ...
- python selenium3 模拟点击+拖动+保存验证码 测试对象 58同城验证码
#!/usr/bin/python # -*- coding: UTF-8 -*- # @Time : 2019/12/5 17:30 # @Author : shenghao/10347899@qq ...
- vue中非父子组件的传值bus的使用
非父子之间的组件传值,可以使用vuex.简单的状态管理,也可以用vue bus vue bus可以实现不同组件间.不同页面间的通信,比如我在A页面出发点击事件,要B页面发生变化,使用方法如下: 全局定 ...
- js重点——作用域——内部原理(二)
本篇是深入分析和理解作用域的第一篇——内部原理和工作模型. 我们知道作用域是变量,对象,函数可访问的一个范围.这说明了我们需要一套良好的规则来存储变量,之后方便查找.所以我们首先要理解的是在哪里而且怎 ...
- C# webserver实现短信发送(移动)
近端时间接了个需求在原来的OA办公系统中添加一个发送短信功能.(既然需要发送短信那肯定要申请一个发送短信的账号,我这里是以移动mas为列子) c#的weserver需要选协议WS.其他的基本不用怎么填 ...
- 【Day3】5.Python中的lxml模块
import lxml.etree as le with open('edu.html','r',encoding='utf-8') as f: html = f.read() html_x = le ...
- Js操作DOM元素及获取浏览器高宽
在JavaScript中,经常会来获取Document文档元素,是 HTML 文档对象模型的英文缩写,Document Object Model for HTML,是基于浏览器编程,HTML DOM ...
- 使用Tarjan进行缩点(有向图)
int From[maxn], Laxt[maxn], To[maxn << 2], Next[maxn << 2], cnt; int low[maxn], dfn[maxn ...