zoukankan      html  css  js  c++  java
  • codevs 2596 售货员的难题

    这题卡空间,只好用dfs。。。加个最短路优(乱)化(搞):当前距离与下一个点的距离与下一个点到终点的最短路之和大于ans则直接剪掉。

    #include<iostream>
    #include<cstdio>
    #include<cstring>
    using namespace std;
    int n,map[20][20],ans=12345678;
    int d[20][20];
    bool vis[20];
    void dfs(int x,int dis,int cnt)
    {
    if ((x==1) && (cnt==n))
    {
    ans=min(ans,dis);
    return;
    }
    vis[x]=true;
    for (int i=1;i<=n;i++)
    {
    if ((dis+map[x][i]+d[i][1]<ans) && ((vis[i]==false) || ((i==1) && (cnt==n-1))))
    dfs(i,dis+map[x][i],cnt+1);
    }
    vis[x]=false;
    }
    int main()
    {
    memset(vis,false,sizeof(vis));
    scanf("%d",&n);
    for (int i=1;i<=n;i++)
    for (int j=1;j<=n;j++)
    scanf("%d",&map[i][j]);
    for (int i=1;i<=n;i++)
    for (int j=1;j<=n;j++)
    d[i][j]=map[i][j];
    for (int k=1;k<=n;k++)
    for (int i=1;i<=n;i++)
    for (int j=1;j<=n;j++)
    if (d[i][j]>d[i][k]+d[k][j])
    d[i][j]=d[i][k]+d[k][j];
    dfs(1,0,0);
    printf("%d ",ans);
    return 0;
    }

  • 相关阅读:
    归并排序
    快速排序
    希尔排序
    插入排序
    选择排序
    冒泡排序
    排序算法
    Win10 家庭版升级到专业版报错
    WPF 原生Style
    在线图片转换
  • 原文地址:https://www.cnblogs.com/ziliuziliu/p/5096469.html
Copyright © 2011-2022 走看看