zoukankan      html  css  js  c++  java
  • Codeforces Round #470 (rated, Div. 2, based on VK Cup 2018 Round 1)

    A. Protect Sheep
    time limit per test
    1 second
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    Bob is a farmer. He has a large pasture with many sheep. Recently, he has lost some of them due to wolf attacks. He thus decided to place some shepherd dogs in such a way that all his sheep are protected.

    The pasture is a rectangle consisting of R × C cells. Each cell is either empty, contains a sheep, a wolf or a dog. Sheep and dogs always stay in place, but wolves can roam freely around the pasture, by repeatedly moving to the left, right, up or down to a neighboring cell. When a wolf enters a cell with a sheep, it consumes it. However, no wolf can enter a cell with a dog.

    Initially there are no dogs. Place dogs onto the pasture in such a way that no wolf can reach any sheep, or determine that it is impossible. Note that since you have many dogs, you do not need to minimize their number.

    Input

    First line contains two integers R (1 ≤ R ≤ 500) and C (1 ≤ C ≤ 500), denoting the number of rows and the numbers of columns respectively.

    Each of the following R lines is a string consisting of exactly C characters, representing one row of the pasture. Here, 'S' means a sheep, 'W' a wolf and '.' an empty cell.

    Output

    If it is impossible to protect all sheep, output a single line with the word "No".

    Otherwise, output a line with the word "Yes". Then print R lines, representing the pasture after placing dogs. Again, 'S' means a sheep, 'W' a wolf, 'D' is a dog and '.' an empty space. You are not allowed to move, remove or add a sheep or a wolf.

    If there are multiple solutions, you may print any of them. You don't have to minimize the number of dogs.

    Examples
    input
    Copy
    6 6
    ..S...
    ..S.W.
    .S....
    ..W...
    ...W..
    ......
    output
    Yes
    ..SD..
    ..SDW.
    .SD...
    .DW...
    DD.W..
    ......
    input
    Copy
    1 2
    SW
    output
    No
    input
    Copy
    5 5
    .S...
    ...S.
    S....
    ...S.
    .S...
    output
    Yes
    .S...
    ...S.
    S.D..
    ...S.
    .S...
    Note

    In the first example, we can split the pasture into two halves, one containing wolves and one containing sheep. Note that the sheep at (2,1) is safe, as wolves cannot move diagonally.

    In the second example, there are no empty spots to put dogs that would guard the lone sheep.

    In the third example, there are no wolves, so the task is very easy. We put a dog in the center to observe the peacefulness of the meadow, but the solution would be correct even without him.

     保护羊群免受狼群骚扰,防不住的就是周围的狼在羊的四联通块上了

    #include<bits/stdc++.h>
    using namespace std;
    char s[505][505];
    main()
    {
        int r,c;
        cin>>r>>c;
        for(int i=1; i<=r; i++)cin>>(s[i]+1);
        for(int i=1; i<=r; i++)
            for(int j=1; j<=c; j++)
                if(s[i][j]=='.')s[i][j]='D';
                else if(s[i][j]=='S'&&(s[i-1][j]=='W'||s[i+1][j]=='W'||s[i][j-1]=='W'||s[i][j+1]=='W'))
                {
                        cout<<"No";
                        return 0;
                }
        cout<<"Yes"<<"
    ";
        for(int i=1; i<=r; i++)cout<<s[i]+1<<"
    ";
    }
    B. Primal Sport
    time limit per test
    1.5 seconds
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    Alice and Bob begin their day with a quick game. They first choose a starting number X0 ≥ 3 and try to reach one million by the process described below.

    Alice goes first and then they take alternating turns. In the i-th turn, the player whose turn it is selects a prime number smaller than the current number, and announces the smallest multiple of this prime number that is not smaller than the current number.

    Formally, he or she selects a prime p < Xi - 1 and then finds the minimum Xi ≥ Xi - 1 such that p divides Xi. Note that if the selected prime palready divides Xi - 1, then the number does not change.

    Eve has witnessed the state of the game after two turns. Given X2, help her determine what is the smallest possible starting number X0. Note that the players don't necessarily play optimally. You should consider all possible game evolutions.

    Input

    The input contains a single integer X2 (4 ≤ X2 ≤ 106). It is guaranteed that the integer X2 is composite, that is, is not prime.

    Output

    Output a single integer — the minimum possible X0.

    Examples
    input
    Copy
    14
    output
    6
    input
    Copy
    20
    output
    15
    input
    Copy
    8192
    output
    8191
    Note

    In the first test, the smallest possible starting number is X0 = 6. One possible course of the game is as follows:

    • Alice picks prime 5 and announces X1 = 10
    • Bob picks prime 7 and announces X2 = 14.

    In the second case, let X0 = 15.

    • Alice picks prime 2 and announces X1 = 16
    • Bob picks prime 5 and announces X2 = 20.

     这个B还是很有难度的,而且你不一定可以读懂题目的

    因为每个合数都可以写成质数的乘积

    所以X1,X0的范围也就是有了,X1取值为[X2-P(X2)+1,X2], X0取值在[X1-P(X1)+1,X1]

    枚举那个最大素数就可以了,暴力完全可以跑过

    # include <iostream>
    using namespace std;
    const int N=1e6+5;
    int a[N];
    int main()
    {
        int n;
        cin>>n;
        for(int i=2; i<=n; i++)
        {
            if(!a[i])
                for(int j=i+i; j<=n; j+=i) a[j]=i;
            a[i]=i-a[i]+1;
        }
        int ans=n;
        for(int i=a[n]; i<=n; i++) ans=min(ans,a[i]);
        cout<<ans;
    }
    C. Producing Snow
    time limit per test
    1 second
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    Alice likes snow a lot! Unfortunately, this year's winter is already over, and she can't expect to have any more of it. Bob has thus bought her a gift — a large snow maker. He plans to make some amount of snow every day. On day i he will make a pile of snow of volume Vi and put it in her garden.

    Each day, every pile will shrink a little due to melting. More precisely, when the temperature on a given day is Ti, each pile will reduce its volume by Ti. If this would reduce the volume of a pile to or below zero, it disappears forever. All snow piles are independent of each other.

    Note that the pile made on day i already loses part of its volume on the same day. In an extreme case, this may mean that there are no piles left at the end of a particular day.

    You are given the initial pile sizes and the temperature on each day. Determine the total volume of snow melted on each day.

    Input

    The first line contains a single integer N (1 ≤ N ≤ 105) — the number of days.

    The second line contains N integers V1, V2, ..., VN (0 ≤ Vi ≤ 109), where Vi is the initial size of a snow pile made on the day i.

    The third line contains N integers T1, T2, ..., TN (0 ≤ Ti ≤ 109), where Ti is the temperature on the day i.

    Output

    Output a single line with N integers, where the i-th integer represents the total volume of snow melted on day i.

    Examples
    input
    Copy
    3
    10 10 5
    5 7 2
    output
    5 12 4
    input
    Copy
    5
    30 25 20 15 10
    9 10 12 4 13
    output
    9 20 35 11 25
    Note

    In the first sample, Bob first makes a snow pile of volume 10, which melts to the size of 5 on the same day. On the second day, he makes another pile of size 10. Since it is a bit warmer than the day before, the first pile disappears completely while the second pile shrinks to 3. At the end of the second day, he has only a single pile of size 3. On the third day he makes a smaller pile than usual, but as the temperature dropped too, both piles survive till the end of the day.

    C这个造雪还是很有意思的,前缀和

    #include<bits/stdc++.h>
    using namespace std;
    typedef long long ll;
    const int N=1e5+5;
    ll V[N],T[N],dy[N],L[N];
    int main()
    {
        int n;
        cin>>n;
        for(int i=1; i<=n; i++)cin>>V[i];
        for(int i=1; i<=n; i++)cin>>T[i],T[i]+=T[i-1];
        for(int i=1; i<=n; i++)
        {
            int pos=upper_bound(T+i,T+n+1,V[i]+T[i-1])-T;
            dy[i]++,dy[pos]--,L[pos]+=V[i]+T[i-1]-T[pos-1];
        }
        for(int i=1; i<=n; i++)dy[i]+=dy[i-1],cout<<dy[i]*(T[i]-T[i-1])+L[i]<<" ";
        return 0;
    }
    D. Perfect Security
    time limit per test
    3.5 seconds
    memory limit per test
    512 megabytes
    input
    standard input
    output
    standard output

    Alice has a very important message M consisting of some non-negative integers that she wants to keep secret from Eve. Alice knows that the only theoretically secure cipher is one-time pad. Alice generates a random key K of the length equal to the message's length. Alice computes the bitwise xor of each element of the message and the key (, where  denotes the bitwise XOR operation) and stores this encrypted message A. Alice is smart. Be like Alice.

    For example, Alice may have wanted to store a message M = (0, 15, 9, 18). She generated a key K = (16, 7, 6, 3). The encrypted message is thus A = (16, 8, 15, 17).

    Alice realised that she cannot store the key with the encrypted message. Alice sent her key K to Bob and deleted her own copy. Alice is smart. Really, be like Alice.

    Bob realised that the encrypted message is only secure as long as the key is secret. Bob thus randomly permuted the key before storing it. Bob thinks that this way, even if Eve gets both the encrypted message and the key, she will not be able to read the message. Bob is not smart. Don't be like Bob.

    In the above example, Bob may have, for instance, selected a permutation (3, 4, 1, 2) and stored the permuted key P = (6, 3, 16, 7).

    One year has passed and Alice wants to decrypt her message. Only now Bob has realised that this is impossible. As he has permuted the key randomly, the message is lost forever. Did we mention that Bob isn't smart?

    Bob wants to salvage at least some information from the message. Since he is not so smart, he asks for your help. You know the encrypted message A and the permuted key P. What is the lexicographically smallest message that could have resulted in the given encrypted text?

    More precisely, for given A and P, find the lexicographically smallest message O, for which there exists a permutation π such that  for every i.

    Note that the sequence S is lexicographically smaller than the sequence T, if there is an index i such that Si < Ti and for all j < i the condition Sj = Tj holds.

    Input

    The first line contains a single integer N (1 ≤ N ≤ 300000), the length of the message.

    The second line contains N integers A1, A2, ..., AN (0 ≤ Ai < 230) representing the encrypted message.

    The third line contains N integers P1, P2, ..., PN (0 ≤ Pi < 230) representing the permuted encryption key.

    Output

    Output a single line with N integers, the lexicographically smallest possible message O. Note that all its elements should be non-negative.

    Examples
    input
    Copy
    3
    8 4 13
    17 2 7
    output
    10 3 28
    input
    Copy
    5
    12 7 87 22 11
    18 39 9 12 16
    output
    0 14 69 6 44
    input
    Copy
    10
    331415699 278745619 998190004 423175621 42983144 166555524 843586353 802130100 337889448 685310951
    226011312 266003835 342809544 504667531 529814910 684873393 817026985 844010788 993949858 1031395667
    output
    128965467 243912600 4281110 112029883 223689619 76924724 429589 119397893 613490433 362863284
    Note

    In the first case, the solution is (10, 3, 28), since  and . Other possible permutations of key yield messages (25, 6, 10), (25, 3, 15), (10, 21, 10), (15, 21, 15) and (15, 6, 28), which are all lexicographically larger than the solution.

     D是裸的01字典树?我不会啊

    #include<bits/stdc++.h>
    using namespace std;
    const int N = 1e6+5;
    int cnt[N*30],nt[N*30][2];
    int tot=1,k;
    long long ans=0;
    int a[N],b[N];
    void Insert(int a,int st,int rt)
    {
        cnt[rt]++;
        if (st==-1)return ;
        int pos=(a>>st)&1;
        if (!nt[rt][pos])nt[rt][pos]=tot++;
        Insert(a,st-1,nt[rt][pos]);
    }
    void Find(int rt,int st)
    {
        cnt[rt]--;
        if(st==-1)
        {
            return;
        }
        int lim=(k>>st)&1;
        if (nt[rt][lim]&&cnt[nt[rt][lim]])Find(nt[rt][lim],st-1);
        else Find(nt[rt][lim^1],st-1),ans^=(1<<st);
        return ;
    }
    int main()
    {
        int n;
        scanf("%d",&n);
        for(int i=0; i<n; i++)scanf("%d",&a[i]);
        for(int i=0; i<n; i++)
            scanf("%d",&b[i]),Insert(b[i],30,0);
        for (int i=0; i<n; i++)
        {
            ans=0,k=a[i];
            Find(0,30);
            printf("%d ",ans);
        }
        return 0;
    }
  • 相关阅读:
    用C++实现网络编程---抓取网络数据包的实现方法
    UNICODE字符串与多字节字符串的转换
    MFC ComboBox的使用
    Windows API学习---线程与内核对象的同步
    Windows API学习---用户方式中的线程同步
    MFC读取XML文件并解析
    Windows API学习---插入DLL和挂接API
    常用[js,css,jquery,html]
    JDBC链接MySQL和Oracle
    使用.NET MVC框架项目开发流程(项目开发流程)
  • 原文地址:https://www.cnblogs.com/BobHuang/p/8571330.html
Copyright © 2011-2022 走看看