manijuana's blog

By manijuana, history, 5 years ago, In English

I'm having trouble implementing a typical dijikstra problem (this one). I'm having a TLE verdict in the last subtask. My submission can be found here. I'm using a set to store the nodes and having a compare function which sorts on the basis of the shortest distances stored in vector d. Everytime a relaxation is encountered, it removes the node, relaxes and changes d[] for that node and enters it again into the set. Can anyone help me get rid of this TLE and tell me why I'm getting one? Thanks in advance.

  • Vote: I like it
  • -1
  • Vote: I do not like it

| Write comment?
»
5 years ago, # |
  Vote: I like it +6 Vote: I do not like it

Use priority_queue instead, it's faster and more useful. A nice implementation can be found at https://cp-algorithms.com/graph/dijkstra_sparse.html

  • »
    »
    5 years ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    I implemented this version of dijikstra from this source only. I didn't use a priority queue cause I wanted to write a shorter code without all those pairs using a set which I'm more comfortable with. But I'm doing something wrong and I can't figure out what :(

»
5 years ago, # |
  Vote: I like it +7 Vote: I do not like it
  • »
    »
    5 years ago, # ^ |
      Vote: I like it +1 Vote: I do not like it

    Thanks a lot I didn't know this at all. I'll remember this now onward. After I fixed that compare function to return false when elements are equal though the last subtask is accepted it shows WA on some other ones which was not the case before. I'm confused and pretty sure the problem is with my comp function but now what is it? Thanks in advance.

    • »
      »
      »
      5 years ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      The reason why I'm so sure that my comparator has a problem is because I submitted the solution with a set of pair of shortest distance and node, and it works fine.

    • »
      »
      »
      5 years ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      Did you just return false when elements are equal or did you change <= into <? Because you should do the latter.

      • »
        »
        »
        »
        5 years ago, # ^ |
          Vote: I like it 0 Vote: I do not like it

        I changed <= to < here is the code but it's getting WA verdict. Whereas when I use this code I get an AC. I can't figure out what's wrong with using a custom made comparator versus the inbuilt one in set.

»
3 years ago, # |
  Vote: I like it 0 Vote: I do not like it

Why i am getting tle for two test cases below is the code could someone tell me what to do

void solve(vector<node>adj[],int n) {
    priority_queue<pair<ll,ll>,vector<pair<ll,ll>>,greater<pair<ll,ll>>>pq;
    vector<ll>dist(n,LLONG_MAX);
    dist[1] = 0;
    pq.push({0,1});

    while(not pq.empty()) {
        ll u =pq.top().second;
        pq.pop();
        
        for(auto i:adj[u]) {
            if(i.des == 1) continue;
            ll v = i.des;
            ll w = i.weight;
            if(dist[u]+w <dist[v]) {
                dist[v] = dist[u] + w;
                pq.push({dist[v],v});
            }
        }
    }

    loop(i,1,n) {
        cout<<dist[i]<<" ";
    }
}

  • »
    »
    3 years ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Don't visit already visited nodes,use an array of mark[],it should work.

    • »
      »
      »
      3 years ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      But suppose you get shortest path from another node , so if mark it visited then there may be possibility i missed some small distance then another route

      • »
        »
        »
        »
        3 years ago, # ^ |
          Vote: I like it 0 Vote: I do not like it
        ll u =pq.top().second;
            pq.pop();
             if(mark[u]==1)
                continue;
            mark[u]=1.

        something like this.

  • »
    »
    3 days ago, # ^ |
      Vote: I like it 0 Vote: I do not like it
    void solve(){
        ll n,m; cin>>n>>m;
        vector<pii>adj[n+1];
        fri(i,1,m){
            ll a,b,c; cin>>a>>b>>c;
            adj[a].pb({b,c});
        }
        vector<ll>dis(n+1,1e18);
        priority_queue<pii, vector<pii>, greater<pii>>pq;
        pq.push({0,1}); dis[1]=0;
        while(!pq.empty()){
            auto cur=pq.top(); pq.pop();
            ll node=cur.second;
            ll node_dis=cur.first;
            
            if(node_dis>dis[node])continue;
    
            for(auto child:adj[node]){
                ll child_node=child.first;
                ll child_dis=child.second;
                if(node_dis+child_dis<dis[child_node]){
                    dis[child_node]=node_dis+child_dis;
                    pq.push({dis[child_node],child_node});
                }
            }
        }
    
        for(ll i=1; i<=n; i++){
            cout<<dis[i]<<" ";
        }cout<<endl;
    }
    
»
2 years ago, # |
  Vote: I like it 0 Vote: I do not like it

use visited array to ensure not visit same node again which is already minimum.