codeforce Round #665(div 2)A B C
A. Distance and Axis
题意:在一个0x轴上,给了a在0x轴上的坐标,要你放一个b点使得abs(0B - AB)的值等于 k,但是有的时候如果不移动A点就不能实现这个条件,所以要你求,移动A点的最小距离,让你满足这个条件。
分析:这是要求0B和AB的差距,也就是它们之间的相差多少,也就是将0A分成三份,两份相同的距离就是0B和AB相同的部分x,还有一部分就是0B和AB的相差距离,也就是k,那么我们就可以表示为2x + k = n,所以我们可以从这个式子中分析出,只要n >= k ,并且n减去一个偶数的结果要等于k这个偶数可以是0,如果没有这样的偶数的话,那么A只需要往后移动一步就可以了,反之一步都可以不用,如果n < k的话,那就可以让A移动到(0,k),这样就可以将B点放在原点就可以了。
下面看AC代码:

#include <bits/stdc++.h>
#include <iostream>
#include <cstdio> using namespace std;
typedef long long ll;
const int ma = 1e5 + ;
int n,m,k,num[ma];
char c[ma];
string s; int main()
{
int t;
scanf("%d",&t);
//2x + k = n
while(t--)
{
scanf("%d%d",&n,&k);
if(n < k)
cout<<k - n<<endl;
else if(n == k)
cout<<<<endl;
else
{
if((n - k) & )
puts("");
else
puts("");
}
}
return ;
}
A
B. Ternary Sequence
题意:输入给出六个数字,前三个数字分别为a的0,1,2的个数,也就是说,x1是有x1个0,y1是有y1个1,z1是有z1个2,并且保证a和b的数字数目相等,要你给a,b序列排序,使得sum值最大,a,b的和是这样求的,如果a[i] > b[i] 那么在第i个的值就是a[i]*b[i],如果相等的话,第i个值就是0,如果小于的话,第i个值就是-a[i]*b[i].
分析:因为只有a[i] > b[i] 才会产生值,也就是说当a[i] == 1,b[i] == 0,和a[i] == 2,b[i] == 1,这两种情况,第一种情况产生的值是0,也就是没意义了,因为它不能给sum做贡献,第二种产生的值就是2(1*2 = 2)了,所以由分析的结果可以知道,必须要a的2尽可能的和b中的1匹配,这样就会让正数最大,因为还有可能会有负数的出现,我们可以分析一下负数出现的可能性,出现负数那就说明a[i] < b[i],当a[i] == 0时,b[i] 可以为1,2。那么分别的结果为-0*b[i]为0,都为0,当a[i] == 1时,b[i] 可以为2,此时的值为-2,因为相等等于0,所以不做贡献就可以不考虑了,所以要让a中的1尽可能的与b中的1,0相匹配,如果还匹配不了,那只能与b中的2匹配了,然后产生负值。
看代码

#include <bits/stdc++.h>
#include <iostream>
#include <cstdio> using namespace std;
typedef long long ll;
const int ma = 1e5 + ;
int n,m,k,num[ma];
char c[ma];
string s; int main()
{
int t;
scanf("%d",&t);
int x1,y1,z1;
int x2,y2,z2;
int sum,minn;
while(t--)
{
scanf("%d%d%d",&x1,&y1,&z1);
scanf("%d%d%d",&x2,&y2,&z2);
sum = ;
minn = min(y2,z1);
sum += *minn;
y2 -= minn,z1 -= minn;
if(y1 <= (y2 + x2))
cout<<sum<<endl;
else
{
cout<<sum - *(y1 - (y2 + x2))<<endl;
}
}
return ;
}
B
C. Mere Array
题意:输入给出一个长度为n的数字序列,要你给它们排序使得它们递增,可以进行两个数的交换,如果满足条件的话,这个条件就是a[i]和a[j]的最大公约数是这个序列的最小值。如果可以交换成这样的序列就输出yes,否则就输出no。
分析:有题意可知,要交换a[i]和a[j],就得有公共的约数min,那没必要交换的我们就可以不要动,所以我们可以检查一下需要交换的所有数是否可以被min整除,如果可以的话,就可以满足条件了,为什么呢?因为我们可以用这个最小数和每个需要交换的数字进行交换,这样就可以保证要交换的两个数的的最大公约数是min了,否则的话就输出no。
代码:

#include <bits/stdc++.h>
#include <iostream>
#include <cstdio> using namespace std;
typedef long long ll;
const int ma = 1e5 + ;
int n,m,k,num[ma];
int c[ma];
string s; int main()
{
int t;
scanf("%d",&t);
int x;
bool f;
while(t--)
{
scanf("%d",&n);
queue<int> q;
for(int i = ; i <= n; i++)
{
scanf("%d",num+i);
c[i] = num[i];
}
sort(c+,c++n);
x = c[];
for(int i = ; i <= n; i++)
{
if(num[i] != c[i])
q.push(num[i]);
}
f = ;
while(!q.empty())
{
if((q.front() % x))
{
f = ;
break;
}
q.pop();
}
if(f)
puts("no");
else puts("yes");
}
return ;
}
C
codeforce Round #665(div 2)A B C的更多相关文章
- Codeforces Round #581(Div. 2)
Codeforces Round #581(Div. 2) CF 1204 A. BowWow and the Timetable 题解:发现,$4$的幂次的二进制就是一个$1$后面跟偶数个$0$. ...
- Codeforces Round #334(div.2)(新增不用二分代码) B
B. More Cowbell time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...
- Codeforces Round #342 (Div 2) 解题报告
除夕夜之有生之年CF第一场 下午从奶奶家回到姥姥家,一看还有些时间,先吃点水果陪姥姥姥爷聊了会儿,再一看表,5:20....woc已经开场20分钟了...于是抓紧时间乱搞.. **A. Guest F ...
- Codeforces Round 1153(div. 2)
这场奇差.ABCD四题.179名. 但是E在现场有213个人做出. 描述一下我在35分钟做完D后的心路历程. 首先看到这道E,第一下想到的是把所有的横向和竖向的整列(行)求出相连的个数. 然后想如何能 ...
- codeforces Round #389(Div.2)C Santa Claus and Robot(思维题)
题目链接:http://codeforces.com/contest/752/problem/C 题意:给出一系列机器人的行动方向(机器人会走任意一条最短路径),问最少标记几个点能让机器人按这个 路径 ...
- Codeforces Round #345 (Div 2)
最后两题是orzCJK学长帮忙代打的,不过总算是到蓝名了(上次睡迟了,只剩半个小时,结果作大死点开题目看,结果rating掉了100多),还有论代码风格的重要性!!!(没写空格被学长各种D) A题 题 ...
- Codeforces Round #622(Div 2)C2. Skyscrapers (hard version)
题目链接 : C2. Skyscrapers (hard version) 题目描述 : 与上一道题类似,只是数据范围变大, 5e5, 如果用我们原来的方法,铁定是超时的. 考察点 : 单调栈,贪心, ...
- Codeforces Round #556(Div.1)
A 容易发现i,i+1至少有一个数出现,于是可以让尽量多的2和奇数出现 #include<bits/stdc++.h> using namespace std; int n,s1,s2; ...
- Codeforces Round #626 (Div. 2) B. Count Subrectangles
题目连接:https://codeforces.com/contest/1323/problem/B 题意:给一个大小为n的a数组,一个大小为m的b数组,c数组是二维数组c[i][j]=a[i]*b[ ...
随机推荐
- 05_MySQL数据库
学于黑马和传智播客联合做的教学项目 感谢 黑马官网 传智播客官网 微信搜索"艺术行者",关注并回复关键词"软件测试"获取视频和教程资料! b站在线视频 软件测试 ...
- Mac上使用Docker安装SQLServer
拉取 SQL Server 2017 Docker 镜像 docker pull microsoft/mssql-server-linux:2017-latest 运行Docker镜像 docker ...
- 【NOIP2016】换教室 题解(期望DP)
前言:状态贼鸡儿多,眼睛快瞎了. ----------------------- 题目链接 题目大意:给定$n(课程数),m(可换次数),v(教室数),e(无向边数)$,同时给定原定教室$c[i]$和 ...
- 苹果挖矿恶意程序处理(OSX/CoinMiner.X)
背景 近期通过流量告警发现多起外连矿池的告警,均外连至43.249.204.231 威胁情报信息如下: 系统表象 1.通过ps -ef|grep osascript发现在/library/Launch ...
- 如何查看Docker容器环境变量,如何向容器传递环境变量
1 前言 欢迎访问南瓜慢说 www.pkslow.com获取更多精彩文章! 了解Docker容器的运行环境非常重要,我们把应用放在容器里执行,环境变量会直接影响程序的执行效果.所以我们要知道容器内部的 ...
- LinuX操作系统基础------>初始并安装系统
b了解LinuX操作系统的来历和发展史 掌握虚拟机(Vbox)的安装方法 掌握CentOS6.5的安装方法 操作系统: 操作系统简称OS ,是管理计算机硬件与软件资源的计算机程序,同时也是计算机系统的 ...
- puppet单机模型
puppet配置 命令 facter -p: 显示所有的变量 puppet apply [-v] [--noop] [-e 'puppet expression: 一般为include httpd等' ...
- Python datetime 转 JSON
Python datetime 转 JSON Python 中将 datetime 转换为 JSON 类型,在使用 Django 时遇到的问题. 环境: Python2.7 代码: import js ...
- C++二分查找:lower_bound( )和upper_bound( )
#include<algorithm>//头文件 //标准形式 lower_bound(int* first,int* last,val); upper_bound(int* first, ...
- Vue 如何优雅的根据条件动态显示组件
常规情况下,在里动态加载不同组件的方式为: <template> <!-- 符合条件A,加载组件A --> <BusinessComponentA v-if=" ...