【XSY2708】hack 网络流

题目描述

  给你一个图,每条边有一个权值。要求你选一些边,满足对于每条从 1 n的路径上(可以不是简单路径)有且仅有一条被选中的边。问你选择的边的边权和最小值。

   n100

题解

  先把整张图分为两个集合 S,T ,其中 S 是从原点开始BFS能够到达的点组成的集合,T是剩下的点组成的集合。

  如果没有在一条路径上只能选一条边的限制,就是一个普通的网络流了。

  我们看看什么情况下这个条件不会被满足。

这里写图片描述

  上面这个图中我们选择了 (1,2) (4,6) S={1,3,4},T={2,5,6}

  可以发现如果多次从 S 走到T(比如上面这张图中 1246 ),那么这些 ST 的边就都被选中同时在同一条路径上。所以不合法。

  所以一旦走到 T 后就不能走回S。  

  如果一条边从 T 指向S,那么这条边的反向边就满流了。

  为了避免这种情况,只需要把反向边的容量设为

  坑点:如果一条边的两个断点与 S T不连通,就不要连边。

  时间复杂度: O( 能过 ) <script type="math/tex" id="MathJax-Element-189">)</script>

代码

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
typedef long long ll;
const ll inf=1e15;
namespace flow
{
    int v[100010];
    ll c[100010];
    int t[100010];
    int h[100010];
    int n;
    void add(int x,int y,ll a)
    {
        n++;
        v[n]=y;
        c[n]=a;
        t[n]=h[x];
        h[x]=n;
    }
    int d[100010];
    int e[100010];
    int op(int x)
    {
        return ((x-1)^1)+1;
    }
    int S,T;
    queue<int> q;
    int num;
    int cur[100010];
    void bfs()
    {
        memset(d,-1,sizeof d);
        d[T]=0;
        q.push(T);
        int x,i;
        while(!q.empty())
        {
            x=q.front();
            q.pop();
            e[d[x]]++;
            for(i=h[x];i;i=t[i])
                if(c[op(i)]&&d[v[i]]==-1)
                {
                    d[v[i]]=d[x]+1;
                    q.push(v[i]);
                }
        }
    }
    ll dfs(int x,ll flow)
    {
        if(x==T)
            return flow;
        ll s=0,u;
        for(int &i=cur[x];i;i=t[i])
            if(c[i]&&d[v[i]]==d[x]-1)
            {
                u=dfs(v[i],min(flow,c[i]));
                s+=u;
                flow-=u;
                c[i]-=u;
                c[op(i)]+=u;
                if(!flow)
                    return s;
            }
        e[d[x]]--;
        if(!e[d[x]])
            d[S]=num;
        d[x]++;
        e[d[x]]++;
        cur[x]=h[x];
        return s;
    }
    ll solve()
    {
        ll ans=0;
        bfs();
        memcpy(cur,h,sizeof h);
        while(d[S]>=0&&d[S]<=num-1)
            ans+=dfs(S,inf);
        return ans;
    }
}
void add(int x,int y,int c)
{
    flow::add(x,y,c);
    flow::add(y,x,inf);
}
int f[110][110];
int lx[2510];
int ly[2510];
int lz[2510];
int n,m;
int main()
{
#ifndef ONLINE_JUDGE
    freopen("b.in","r",stdin);
    freopen("b.out","w",stdout);
#endif
    scanf("%d%d",&n,&m);
    int i,j,k;
    for(i=1;i<=m;i++)
    {
        scanf("%d%d%d",&lx[i],&ly[i],&lz[i]);
        lx[i]++;
        ly[i]++;
        f[lx[i]][ly[i]]=1;
    }
    for(k=1;k<=n;k++)
        for(i=1;i<=n;i++)
            if(i!=k&&f[i][k])
                for(j=1;j<=n;j++)
                    if(j!=i&&j!=k)
                        f[i][j]|=f[i][k]&&f[k][j];
    for(i=1;i<=n;i++)
        f[i][i]=1;
    flow::S=1;
    flow::T=n;
    flow::num=n;
    for(i=1;i<=m;i++)
        if(f[1][lx[i]]&&f[ly[i]][n])
            add(lx[i],ly[i],lz[i]);
    ll ans=flow::solve();
    if(ans>=inf)
        printf("-1\n");
    else
        printf("%lld\n",ans);
    return 0;
}
内容概要:该专利提出了一种节能高效的双螺杆压缩机转子型线设计方案,属于动力传动与控制技术领域。核心创新点在于阴阳转子的齿曲线采用抛物线、圆弧、椭圆及其共轭包络线组合而成,形成二次曲线与二次曲线包络线的组合型线。设计特点包括非对称齿面(前齿面更宽,b/a>1.8)、各段曲线光滑连接无尖点、七段曲线组合结构。该设计旨在提高密封性、改善动力特性、降低损耗、提升效率,从而提高双螺杆压缩机的整体性能。文中提供了详细的Python代码实现,包括转子型线的计算和可视化,以及改进后的代码,以更好地反映专利的具体参数和技术细节。 适合人群:机械工程专业人员、从事压缩机设计与制造的技术人员、对双螺杆压缩机转子型线设计感兴趣的科研人员。 使用场景及目标:①用于研究和开发新型双螺杆压缩机,特别是在提高压缩机效率和性能方面;②作为教学案例,帮助学生和工程师理解双螺杆压缩机转子型线的设计原理和技术实现;③为企业提供参考,优化现有产品的设计和制造工艺。 其他说明:文中提供的代码基于专利描述进行了合理的假设和简化,实际应用中可能需要根据具体性能要求进行优化调整。专利技术通过非对称设计、多段曲线组合等方式,实现了高效的密封性和优良的动力特性,显著提升了双螺杆压缩机的性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值