首页 > 其他分享 >(AtCoder Beginner Contest 289)And Codeforces Round #851 (Div. 2)

(AtCoder Beginner Contest 289)And Codeforces Round #851 (Div. 2)

时间:2023-02-26 18:55:47浏览次数:62  
标签:AtCoder 851 Beginner int cin state include sides dp

 

<C - Coverage Editorial>

  

 

 

 

 

 

 

     这道题可以用dfs进行爆搜,但是在爆搜的时候要注意:

    是否同一个状态重复计数了

    比如 dfs(int x,int state) 表示看第x个set的时候,是否选择Cx,目前state(是用二进制表示的是否含有第i个数的值)

    可能在这个时候我就已经满足条件了ans++,目前是否选择Ci的状态是00001111(第i位代表着是否选择了Ci)

    但是还不能返回,这个时候还要继续搜下去,搜到最后可能状态还是00001111,重复了

    要避免在这个情况下ans还++

 

    用dp可以不用去考虑这种情况

    dp[i][state]:表示 在前i个set中选择,导致是否含有第i个数的状态为state的方案数

    状态转移:

      dp[i][state]+=dp[i-1][state]

      dp[i][state“+”states[i]]+=dp[i-1][state]

      (“+”表示特殊操作,具体看代码)

#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
int n, m;
int dp[12][10000];
int states[12];
int get(int j, int state)
{
    int ans = 0;
    for (int i = 1; i <= n; i++)
    {
        int b1 = (j >> (i - 1)) & 1, b2 = (state >> (i - 1)) & 1;
        int b = b1 | b2;
        if (b)
            ans += (1 << (i - 1));
    }
    return ans;
}
int main()
{
    cin >> n >> m;
    int need = ((1 << n) - 1);
    for (int i = 1; i <= m; i++)
    {
        int g;
        cin >> g;
        for (int j = 1; j <= g; j++)
        {
            int num;
            cin >> num;
            states[i] += (1 << (num - 1));
        }
    }
    dp[0][0] = 1;
    for (int i = 1; i <= m; i++)
        for (int j = 0; j <= need; j++)
        {
            dp[i][j] += dp[i - 1][j];
            dp[i][get(j, states[i])] += dp[i - 1][j];
        }
    cout << dp[m][need];
    return 0;
}

 

《D - Step Up Robot》

 

 

   dp[x]:表示是否能到第x阶梯

  状态转移:

    dp[x]|=dp[x-steps[i]]  (steps[i]是枚举的一次能够上多少个阶梯)

  

#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
int n, as[12], m, x;
bool traps[100001];
int dp[100001];
int main()
{
    cin >> n;
    for (int i = 1; i <= n; i++)
        cin >> as[i];
    cin >> m;
    for (int i = 1; i <= m; i++)
    {
        int t;
        cin >> t;
        traps[t] = true;
    }
    cin >> x;
    dp[0] = 1;
    for (int i = 1; i <= x; i++)
    {
        for (int j = 1; j <= n; j++)
        {
            if (i >= as[j] && !traps[i - as[j]])
                dp[i] |= dp[i - as[j]];
        }
    }
    if (dp[x])
        cout << "Yes" << endl;
    else
        cout << "No" << endl;
    return 0;
}

 

 

《E - Swap Places 》

 

 

  有点类似dp的思想,dp[T][A]:表示从初始的状态到Takahashi在点T,Aoki在点A时的这个状态的最小步数

  然后状态的转移通过bfs来实现

  其实如果先不考虑两个人走,一个人在一个图上,从一个点到另一个点的最小距离(在边权重都为1的情况下)

  其实就是可以用BFS来做

  现在这里两个人走,只是加了一点限制条件,方法还是一样的

   

#include <iostream>
#include <algorithm>
#include <cstring>
#include <vector>
#include <queue>
using namespace std;
typedef pair<int, int> PII;
const int INF = 0x3f3f3f3f;
int color[2001], t, n, m;
int bfs(int sta, int fin, vector<vector<int>> sides)
{
    vector<vector<int>> dp(n + 1, vector<int>(n + 1, INF));
    queue<PII> s;
    s.push({sta, fin});
    dp[sta][fin] = 0;
    while (s.size())
    {
        auto t = s.front();
        s.pop();
        for (int a : sides[t.first])
            for (int b : sides[t.second])
            {
                if (color[a] != color[b] && dp[a][b] > dp[t.first][t.second] + 1)
                {
                    s.push({a, b});
                    dp[a][b] = dp[t.first][t.second] + 1;
                }
            }
    }
    return dp[n][1];
}
int main()
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    cin >> t;
    while (t--)
    {
        cin >> n >> m;
        vector<vector<int>> sides(n + 1);
        for (int i = 1; i <= n; i++)
            cin >> color[i];
        for (int i = 1; i <= m; i++)
        {
            int a, b;
            cin >> a >> b;
            sides[a].push_back(b), sides[b].push_back(a);
        }
        int ans = bfs(1, n, sides);
        if (ans >= INF)
            cout << -1 << endl;
        else
            cout << ans << endl;
    }
    return 0;
}

 

 

《F - Teleporter Takahashi Editorial》 

  

 

 

  这道题目前我还是具体代码写不出(一些细节边界问题搞不出)

  但是给了我一点写二维题目的启发:

    将二维问题转化为一维问题来解决

  

 

 

     首先面对这道题,不能只考想象,要实际去动手画一下

    想要将sx到tx,会发现

       如 (sx,sy)关于(a,c)对称得到点(x,y)

    (x,y)在关于(a+1,c)对称得到点(sx+2,y)

   发现保持对称中心点的y不变,可以达到只改变x,而y不变的方法

   不断通过上述操作,可以判断出是否可以sx->tx

   y同理

   同时还可以结合数学公式去理解

 

 

    

  

  

标签:AtCoder,851,Beginner,int,cin,state,include,sides,dp
From: https://www.cnblogs.com/cilinmengye/p/17157296.html

相关文章

  • AtCoder Beginner Contest 281 A-F 题解
    比赛链接A-CountDown先这样,就这样。点击查看代码#include<cstdio>intn;intmain(){ scanf("%d",&n); for(inti=n;i>=0;i--)printf("%d\n",i); re......
  • 【pywin32】使用win32com操作Excel,报错com_error -2147417851
    帮写一个界址点成果表输出程序,基于ArcPy取数据,采用win32com操作Excel。在客户机报错如下: 系统MSOffice为购机预装阉割版,卸载,otp重装,仍然报错。怀疑是WPS Office篡改......
  • AtCoder Beginner Contest 287 A-F 题解
    比赛链接A-Majority先这样再那样最后这样,就是这样。点击查看代码#include<cstdio>#include<algorithm>#include<cstring>usingnamespacestd;intn,a;char......
  • AtCoder Beginner Contest 286 A-G 题解
    比赛链接A-RangeSwap根据题意,分段输出。点击查看代码#include<cstdio>#include<algorithm>#include<cstring>usingnamespacestd;constintN=105;intn,......
  • AtCoder Beginner Contest 288 解题报告
    AtCoderBeginnerContest288解题报告\(\text{ByDaiRuiChen007}\)A.ManyA+BProblems直接模拟即可时间复杂度\(\Theta(n)\)#include<bits/stdc++.h>usingname......
  • AtCoder Beginner Contest 282 A-F 题解
    比赛链接A-GeneralizedABC额,对,是的,没错,先这样再那样然后这样就是这样。点击查看代码#include<cstdio>intn;intmain(){ scanf("%d",&n); for(inti=0;......
  • AtCoder Beginner Contest 285 A-F 题解
    比赛链接A-EdgeChecker2判断y==2x||y==2x+1即可。点击查看代码#include<cstdio>#include<algorithm>#include<cstring>usingnamespacestd;inta......
  • AtCoder Beginner Contest 283 A-F 题解
    A-Power快速幂板子点击查看代码#include<cstdio>#include<algorithm>usingnamespacestd;#defineintlonglongintn,m;intqpow(inta,intb){ intr......
  • AtCoder Beginner Contest 139
    AtCoderBeginnerContest139https://atcoder.jp/contests/abc1395/6:今天前4题都很水,e还可以但是比较基础,f是计算几何的一个结论,挺没意思的,还是昨天的f比较好玩A-Ten......
  • Atcoder试题乱做 Part7
    怎么说呢,\(Clash\)真好用,\(Privado\)再见.\(\text{[ABC219H]Candles}\)\(\color{green}{\text{[EASY]}}\)联考见过类似的,直接设\(f_{l,r,i,0/1}\)表示覆盖了......