`
暴风雪
  • 浏览: 391929 次
  • 性别: Icon_minigender_2
  • 来自: 杭州
社区版块
存档分类
最新评论

Codeforces Round #266 (Div. 2)

 
阅读更多

赛后练习,慢慢找感觉

A要考虑很多种情况,特别是坐m站路车的距离大于n但是更便宜的情况

 #include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
int n,m,a,b;
int main(){
    while(cin>>n>>m>>a>>b){
        int x=a*m;
        if(x<b){
            cout<<a*n<<endl;
        }else{
            int res=0;
            if(m>n){
                if(b>n*a){
                    res=n*a;
                }else{
                    res=b;
                }
            }else{
                res+=(n/m*b);
                res+=n%m*a;
                res=min(res,n/m*b+b);
            }
            cout<<res<<endl;
        }
    }
    return 0;
}

 B,贪心思路,从6*n开始向上枚举房间的面积,存在符合的则输出,注意要用int64

#include<iostream>#include<cstring>#include<cstdio>#include<cmath>usingnamespace std;longlong n,a,b;int inprim(longlong aaa,longlong&beg,longlong&edd){longlong i;longlong k=sqrt(aaa);for(i=beg;i<=k;i++){if(aaa%i==0&&aaa/i>=edd){
            beg=i;
            edd=aaa/i;return i;}}return-1;}int main(){while(scanf("%I64d",&n)!=EOF){
        scanf("%I64d%I64d",&a,&b);if(n*6<=a*b){
            printf("%I64d\n",a*b);
            printf("%I64d %I64d\n",a,b);continue;}
        n*=6;longlong res;while(1){longlong edd=max(a,b);longlong beg=min(a,b);longlong flag=inprim(n,beg,edd);if(flag!=-1){
                res=beg*edd;if(a<=beg){
                    a=beg,b=edd;}else{
                    b=beg,a=edd;}break;}
            n++;}
        printf("%I64d\n",res);
        printf("%I64d %I64d\n",a,b);}return0;}

 

C,比B要水,遍历两遍即可

#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
int num[600000],n,dp[600000];
int main(){
    int i;
    long long sum,res;
    while(scanf("%d",&n)!=EOF){
        res=sum=0;
        for(i=1;i<=n;i++){
            scanf("%d",&num[i]);
            sum+=num[i];
        }
        if(sum%3!=0){
            printf("0\n");
            continue;
        }
        sum/=3;
        memset(dp,0,sizeof(dp));
        long long suml=0,sumr=0;
        for(i=n;i>0;i--){
            sumr+=num[i];
            dp[i]=dp[i+1];
            if(sumr==sum){
                dp[i]++;
            }
        }
        for(i=1;i<n;i++){
            suml+=num[i];
            if(suml==sum){
                res+=dp[i+2];
            }
        }
//        for(i=1;i<=n;i++)cout<<dp[i]<<" ";
//        cout<<endl;
        printf("%I64d\n",res);
    }
    return 0;
}

 D 没看懂样例,留着坑回来填

E 并查集的好题,题意是给出一些人和他上司的关系图,第a个人知道第i条消息后,这个人的上司以及上司的上司都会知道这个消息。在线的询问,第x人知不知道第k条消息

       这题技巧在于,每次都记录知道第i条消息人关系链的头和尾,输入第x个人和第i条消息后,看他是不是在第i条消息关系链的头和尾上即可。

#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
const int nMax=100005;
int father[nMax],boss[nMax];
int find(int x){ // 寻找父节点
    if(x!=father[x])
        return father[x]=find(father[x]);
    return x;
}
void init(){    // 初始化
    int i;
    for(i=0; i<nMax-1; i++){
        boss[i]=father[i]=i;
    }
}
int vv1[nMax],vv2[nMax];
int main(){
    int n,m,a,b,c,nk;
    while(scanf("%d%d",&n,&m)!=EOF){
        init();
        nk=1;
        while(m--){
            scanf("%d",&a);
            if(a==1){
                scanf("%d%d",&b,&c);
                boss[b]=c;
                father[b]=c;
            }else if(a==2){
                scanf("%d",&b);
                vv1[nk]=b;
                vv2[nk++]=find(b);  //第nk条信息由第b人穿到第findb人
            }else if(a==3){
                scanf("%d%d",&b,&c);  //第b个人,第c条信息
                bool flag=0;
                int beg=vv1[c];
                int edd=vv2[c];  //第c条消息的开始和结束
                while(true){
                    if(beg==b){
                        flag=1;
                        break;
                    }if(beg==edd){
                        break;
                    }
                    beg=boss[beg];
                }
                if(flag){printf("YES\n");}
                else printf("NO\n");
            }
        }
    }
    return 0;
}

 

1
2
分享到:
评论

相关推荐

    Codeforces Round #723 (Div. 2).md

    Codeforces Round #723 (Div. 2).md

    Codeforces Round 961 (Div. 2) 编程竞赛的详细解析

    codeforces round 961 (div. 2)

    Codeforces Round 961 (Div. 2):深度解析与实战技巧.pdf

    ### Codeforces Round 961 (Div. 2):深度解析与实战技巧 #### 引言 Codeforces 是一个国际知名的在线编程竞赛平台,它汇聚了来自世界各地的编程爱好者和专业人士。每一轮比赛都旨在测试参赛者的算法思维、编程...

    codeforces round 962 (div. 3)tion-ma笔记

    codeforces round 962 (div. 3)tion-ma笔记

    codeforces round 961 (div. 2)

    ### Codeforces Round 961 (Div. 2) A题解析 #### 题目背景 Codeforces Round 961 (Div. 2) 是一场针对中级水平程序员的编程竞赛,通常会包含几个不同难度级别的题目。A题作为入门级题目,旨在测试参赛者的基础算法...

    codeforces round 962 (div. 3).docx

    Codeforces Round 962 (Div. 3) 是一场编程竞赛,其中包含了多个编程题目,每个题目都有其独特的挑战和解题思路。以下是对该竞赛中部分题目的简要介绍及解题思路概述: A题: Legs 题意: 一只鸡有2条腿,一头奶牛有...

    codeforces round 962 (div. 3) .zip

    Codeforces Round 962 (Div. 3) 是一场编程竞赛,旨在测试参赛者在算法和数据结构方面的能力。由于篇幅限制,我将对这场竞赛中的几个关键问题进行详细解析,但请注意,由于具体实现细节可能因题目而异,且无法在此...

    Codeforces Round 964 (Div. 4).pdf

    A~G

    Codeforces Round #627 (Div. 3) C. Frog Jumps(思维)

    传送门 题意: 开始位置在0,问能否跳到n+1位置 每步只能跳d 在1——n每个位置有方向,L,R,求d的最小值 思路: 只用找相邻两个R之间的最大值即可 代码: #include #include ...typedef long long l

    Codeforces Round #627 (Div. 3) B. Yet Another Palindrome Problem

    就是把所有相等的数放到一个vector里,如果他出现大于2次,看最远的间距是否大于2即可,找到一个就可以 代码: #include #include #include #include #include #include #include #include #include #include #...

    Codeforces Round #479 (Div. 3) E. Cyclic Components

    E. Cyclic Components 题目链接-E. Cyclic Components 题目大意 给你nnn个点和mmm条边,求所构成图中单圈环的个数 ...并查集并查集并查集 很明显单圈环每个点的度都为222,所以我们可以用数组cnt[]记录每个点的度,...

    Codeforces Round #629 (Div. 3) E.Tree Queries (DFS)

    Codeforces Round #629 (Div. 3) E.Tree Queries (DFS) 思路:若ai 在路径上 ,则ai的父结点一定在路径上,若ai是路径上某个结点的子结点,则ai的父结点一定在路径上,综上只需考虑ai的父节点就行了。对每个ai判断...

    Codeforces Round #627 (Div. 3) D. Pair of Topics(二分,思维)

    ### Codeforces Round #627 (Div. 3) D. Pair of Topics(二分,思维) #### 题目背景与概述 本题目来自Codeforces Round #627 (Div. 3),编号为D的题目“Pair of Topics”,这是一道结合了二分搜索与逻辑思维的...

    Codeforces Round #629 (Div. 3) E – Tree Queries dfs序判祖先关系

    标题中的"Codeforces Round #629 (Div. 3) E – Tree Queries dfs序判祖先关系"指的是一场编程竞赛中的问题,涉及到树结构的查询和深度优先搜索(DFS)来判断节点间的祖先关系。这个问题的目标是设计算法来确定在...

    Codeforces Round #618 (Div. 2) C. Anu Has a Function(进制,位运算,贪心)

    题目“Anu Has a Function”源自Codeforces Round #618 (Div. 2)的一道竞赛编程问题,主要涉及进制转换、位运算和贪心算法。问题要求定义一个函数f(x, y) = (x | y) - y,并对数组进行排序,以最大化最后的结果。 ...

    Codeforces Round 962

    Codeforces Round 962 (Div. 3) 编程竞赛 Codeforces Round 962 (Div. 3) 编程竞赛 Codeforces Round 962 (Div. 3) 编程竞赛 Codeforces Round 962 (Div. 3) 编程竞赛

    Codeforces Round #628 (Div. 2)

    给两两节点放一个数字(0~n-2 唯一) 给你一棵树,求所有任意两节点相连的路以外的路上的数字的最小值最小 思路 构造 若一个点连了三条边及以上,则这个点的边从最小值开始赋值。其他边从最大点开始赋值。 证明:一...

    Codeforces Round #627 (Div. 3) A. Yet Another Tetris Problem

    给一个长度为n的数组,两种操作,一个是把任意一个ai变成ai+2a_i变成a_i+2ai​变成ai​+2,另一个是如果所有数都大于0,可以把所有数减1,问通过这些操作能否把所有数变为0 思路: 如果任意两个数之差为奇数,那么就...

    Codeforces Round #628 (Div. 2) A. EhAb AnD gCd

    输入一个正整数x,找出这样的2个正整数a和b,使得gcd(a,b)+lcm(a,b)=x 解题思路 找最特殊的情况a=1,b=x-1即可 这样a,b两个数最大公因数为1,最小公倍数x-1,满足题意√ 附上代码 #include #define int long long #...

Global site tag (gtag.js) - Google Analytics