CF每日一练(2.9)

CF-1013

A. Piles With Stones

比较两个序列的和,因为只能拿走或者不拿,所以总数不能变大。

B. And

  • 答案只有 -1,0,1,2几种可能,所以对于每一种答案都暴力扫一次是可以的
  • 或者对于每个 \(a_i\) ,将\(a_i\) 标记加一,如果\(a_i \neq a_i\& x\) ,将\(a_i\&x\) 用另一个数组标记加一。然后整体扫一次就可以了
#include <bits/stdc++.h>
using namespace std;
int n,x;
int a[100010],b[100010];
int main(){
    cin>>n>>x;
    for(int i=1;i<=n;i++){
        int y;
        scanf("%d",&y);
        a[y]++;
        if((x&y)!=y)
            b[x&y]++;
    }
    int res = -1;
    for(int i=0;i<=100000;i++)
    {
        if(a[i]>=2)res = 0;
        else if(res!=0&&a[i]==1&&b[i]>=1)res = 1;
        else if(res!=1&&b[i]>=2)res = 2;
    }
    cout<<res<<endl;
    return 0;
}

C. Photo of The Sky

我们关心的只是 \(x_{max} - x_{min}\) 和 \(y_{max} - y_{min}\)

现在的只是整个坐标的合集。先整体排个序。

? \[ a_1,a_2 \cdots a_{2\times n-1},a_{2 \times n}\]

  • 如果序列中最大值和最小值在同一个集合,那么枚举另一个集合的最大元素或者最小元素,得到另一个集合的最小的 \(max - min\)
  • 如果序列中最大值和最小值不在同一个集合,那么只有将 \(a_1 \cdots a_n\) 分到一个集合,\(a_{n+1} \cdots a_{2\times n}\) 分到一个集合时最优
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int n;
ll a[200010];
int main(){
    scanf("%d",&n);
    for(int i=0;i<2*n;i++)
        scanf("%lld",&a[i]);
    sort(a,a+2*n);
    ll mi = 1ll<<60;
    //第一种情况,枚举另一个集合的最小值a[i]
    for(int i=1;i<n;i++)
        mi = min(mi,a[i+n-1]-a[i]));
    mi = mi*(a[2*n-1]-a[0]);//结算,获得面积
    mi = min(mi,(a[n-1]-a[0])*(a[2*n-1]-a[n]));//与第二种情况作比较
    cout<<mi<<endl;
    return 0;
}

D. Chemical table

tag: 并查集,联通块

题目操作:若有\((r_1,c_1),(r_1,c_2),(r_2,c_1)\) ,那么自动生成\((r_2,c_2)\)

抛开二维平面,寻找坐标点之间的关系,可以发现一条规律:如果\(r_1\)与\(c_1,r_2\)有关系,\(r_2\)与\(c_2\)有关系,则\(r_2\)与\(c_2\)会有关系。如果把他们看成点与点之间的关系,可以画出一个图,这个图是联通的。而任意两个不联通的点只需要再添加一个点就可以使得他们联通。所以我们只需要求出联通块个数就可以知道答案了。

#include <bits/stdc++.h>
using namespace std;
int n,m,q;
int f[400010];
//并查集
int find(int x){
    return x==f[x]? x : f[x] = find(f[x]);
}
int main(){
    cin>>n>>m>>q;
    for(int i=1;i<=n+m;i++)f[i] = i;
    for(int i=0;i<q;i++){
        int x,y;
        cin>>x>>y;
        y+=n;
        x = find(x);y=find(y);
        f[x] = y;
    }
    //先随便找一个联通块
    int root = find(1);
    int res = 0;
    for(int i=2;i<=n+m;i++){
        int x = find(i);
        //如果发现另一个联通块,则先使得他们联通,然后res++
        if(x!=root){
            f[x] = root;res++;
        }
    }
    cout<<res<<endl;
    return 0;
}

原文地址:https://www.cnblogs.com/chd-acm/p/10357932.html

时间: 2024-07-31 17:12:50

CF每日一练(2.9)的相关文章

CF每日一练(2.10)

CF-1093 1093A - Dice Rolling 输出x/2即可 #include<bits/stdc++.h> using namespace std; int main() { int t; cin >> t; while (t--) { int x; cin >> x; cout << x / 2 << endl; } return 0; } 1093B - Letters Rearranging 当且仅当字符串中所有字符都相同时,

CF每日一练(2.11)

CF-1114 A. Got Any Grapes? skip B. Yet Another Array Partitioning Task 将n个数分成连续的k组,使得每组的前m大的数字的总和最大. 首先可以想到肯定可以包含n个数中前 m*k 大的数.所以可以先将他们标记,然后扫一遍确定每组的端点即可 #include <bits/stdc++.h> using namespace std; typedef long long ll; int n,m,k; struct node{ int

CSS3每日一练之内容处理-嵌套编号

出处:http://www.w3cfuns.com/thread-5592229-1-17.html 1.大标题一   1.子标题   2.子标题   3.子标题2.大标题二   1.子标题   2.子标题3.大标题三   1.子标题   2.子标题   3.子标题 这种问题,你可能会觉得直接定义两个计数器,分别编号不就行了,于是就写出了如下代码: <!DOCTYPE HTML> <html> <head> <meta charset="gb2312&q

每日一小练——最长平台问题

上得厅堂,下得厨房,写得代码,翻得围墙,欢迎来到睿不可挡的每日一小练! 题目:最长平台问题 内容:一直一个已经从小到大排序的数组,这个数组中的一个平台就是连续的一串同样的元素.而且这个元素不能再延伸. 比如,在1,2,2,3,3,3,4,5,5,6中1,2,2,3,3,3,4,5,5,6都是平台.试编写一个程序,接受一个数组,把这个数组中最长的平台找出来.在这个样例中, 3,3,3就是该数组的中的最长的平台. 说明: 这个程序十分简单,可是编写好却不easy,因此在编敲代码时应注意考虑以下几点:

每日一小练——列出全部子集

上得厅堂,下得厨房,写得代码,翻得围墙,欢迎来到睿不可挡的每日一小练! 题目:列出全部子集 内容:写一个程序,列出{1,2,3,4,...,n}这个集合的全部子集,包含空集{ }. 解决问题的算法应该有非常多种,只是我发现了一种非常easy也非常好玩的方法,就是用二进制表示几何元素的方法 比方假设n是3,则子集有(不包含空集){1}{2}{3}{1,2}{1,3}{2,3}{1,2,3}就是1*{0,1}and2*{0,1}and3{0,1}每一个组合出现一次,所以也能够看成是{0,0,1}{0

每日一小练——按字典顺序列出所有排列

上得厅堂,下得厨房,写得代码,翻得围墙,欢迎来到睿不可挡的每日一小练! 题目:按字典顺序列出所有排列 内容:请写一个程序,用字典顺序列出n个元素的所有排列 这个问题有点小复杂,不是太好想,反正我是想了好久. 看到这个题目我先是想到的就是递归因为这个题目就是用指针对高位选择,然后将指针传给临近的低位再选择. 不过仔细研究原来没这么简单.以n=4举例当处理以1开头的排列时1234到1432,但是在排列2开头的时候不太好建立统一的递归关系.(没办法太统一的递归方法中将后面的数字选出来),所以将第一位分

每日一小练——快速Fibonacci数算法

上得厅堂,下得厨房,写得代码,翻得围墙,欢迎来到睿不可挡的每日一小练! 题目:快速Fibonacci数算法 内容:先说说Fibonacci数列,它的定义是数列:f1,f2....fn有如下规律: 尝试寻找快速的求出fn的方法 我的解法:上来没多想,打开vs2013就敲了起来,问题果然很简单,分分钟就超神..奥,不对就解决了! 其实题目中就给出了这个算法的递归形式,所以首先我想到的是递归解法,不过因为求解快速方法在递归之前,我编写了一个非递归的算法 #include <iostream> usi

CSS3每日一练之选择器-结构性伪类选择器

<!DOCTYPE HTML> <html> <head> <meta charset="gb2312"> <title>CSS3每日一练之选择器-结构性伪类选择器[四] | 前端开发网(W3Cfuns.com)!</title> <style type="text/css"> *{margin:0; padding:0;} #list{font-family:"Micro

每日一小练——按字典顺序列出全部子集

上得厅堂,下得厨房,写得代码,翻得围墙,欢迎来到睿不可挡的每日一小练! 题目:按字典顺序列出全部子集 内容: 请写一个程序用字典顺序把一个{1,2,3,4,...,n}集合的全部子集找出来. 解答: 想必我就不用解释什么是字典顺序了,作为乘虚猿和攻城狮大家应该懂得,无论你懂不懂,反正我懂了! 事实上我们能够先列出一个实例,观察规律: 比如n=3 {1} {1,2} {1,2,3} {1,3} {2} {2,3} {3} 能够看出这种规律(假设你说我怎么没看出来,事实上你能够再多看一会!) 令一个