测试

我能吞下玻璃而不伤身体。
I can eat glass, it doesn't hurt me.

我能吞下玻璃而不伤身体。
I can eat glass, it doesn't hurt me.

我能吞下玻璃而不伤身体。
I can eat glass, it doesn't hurt me.

我能吞下玻璃而不伤身体。
I can eat glass, it doesn't hurt me.

我能吞下玻璃而不伤身体。
I can eat glass, it doesn't hurt me.

1.我能吞下玻璃而不伤身体。
2.I can eat glass, it doesn't hurt me.

  • 我能吞下玻璃而不伤身体。
  • I can eat glass, it doesn't hurt me.

我能吞下玻璃而不伤身体。
I can eat glass, it doesn't hurt me.

\(dp(j)=min(dp(j),dp(j-w[i])+v[i])\)

\[dp(j)=min(dp(j),dp(j-w[i])+v[i]) \]

\(1 \le 2\)

\[1 \le 2 \]
#include <bits/stdc++.h>
using namespace std;
#define MAXN 100005
#define F 15
#define R 200
#define INF 0x7fffffff
vector<pair<int,int> > g[MAXN];
int n,m,s,dis[MAXN],cnt[MAXN];
inline int read(){
   int s=0,w=1;
   char ch=getchar();
   while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}
   while(ch>='0'&&ch<='9') s=s*10+ch-'0',ch=getchar();
   return s*w;
}
void SPFA(){
    deque<int> q;
    q.push_back(s);
    while(!q.empty()){
        int u=q.front();
        q.pop_front();
        for(int i=0;i<g[u].size();i++){
            int v=g[u][i].first,w=g[u][i].second;
            if(dis[v]>dis[u]+w){
                dis[v]=dis[u]+w;
                if(cnt[v]>R){
                    q.push_back(v);
                }else if(dis[q.front()]>=dis[v]-F){
                    q.push_front(v);
                }else{
                    q.push_back(v);
                }
                cnt[v]++;
            }
        }
    }
}
int main(){
    srand(time(NULL));
    n=read();
    m=read();
    s=read();
    for(int i=1;i<=m;i++){
        int u,v,w;
        u=read();
        v=read();
        w=read();
        g[u].push_back(make_pair(v,w));
    }
    for(int i=1;i<=n;i++){
        random_shuffle(g[i].begin(),g[i].end());
    }
    fill(dis+1,dis+1+n,INF);
    dis[s]=0;
    SPFA();
    for(int i=1;i<=n;i++){
        printf("%d ",dis[i]);
    }
    printf("\n");
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值