类似0-1背包的dfs:选与不选

题目链接:https://ac.nowcoder.com/acm/contest/331/D
题目大意:
类似0-1背包的dfs:选与不选_第1张图片
类似0-1背包的dfs:选与不选_第2张图片
思路:每个传送阵可以选择传送或者不传送。
从n->1开始考虑。从终点最远的传送阵开始枚举

#include
using namespace std;
#define LL long long
struct NODE
{
    int x, y;
}node[16];

int cmp(NODE a, NODE b)
{
    return a.y>b.y;
}

LL T(LL l, LL r)     //从l到r不经过传送阵的最少时间
{
    LL s=r-l;
    if(s==0)
    {
        return 0;
    }
    if(s==1)
    {
        return 1;
    }
    LL c=(LL)log2(s);
    c=r-pow(2, c);
    return  T(l, c)+1;

}

LL dfs(int n, int cut)
{
    if(cut==0)
    {
        return T(1, n);
    }
    else if(n>=node[cut].y)  //如果当前位置>传送阵的终点:选择传送或者不传送的最少时间的方案
    {
        return min(dfs(n, cut-1),dfs(node[cut].x, cut-1)+T(node[cut].y, n)+1);
    }
    else
    {
        return dfs(n, cut-1);//如果当前位置<传送阵的终点:只能选择不传送
    }
}

int main()
{
    LL n;
    int k, cut=1, u, v;
    scanf("%lld%d",&n,&k);
    for(int i=1;i<=k;i++)
    {
        scanf("%d%d",&u,&v);
        if(u!=v)
        {
            node[cut].x=u;
            node[cut++].y=v;
        }
    }
    sort(node+1, node+cut+1, cmp); //从终点最大的传送阵开始选择
    cout<<dfs(n, cut-1)<<endl;     //从n->1

	return 0;
}

你可能感兴趣的:(dfs)