QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#410475#676. Travelling MerchantSirPh#0 89ms5496kbC++202.2kb2024-05-14 02:54:182024-05-14 02:54:19

Judging History

你现在查看的是最新测评结果

  • [2024-05-14 02:54:19]
  • 评测
  • 测评结果:0
  • 用时:89ms
  • 内存:5496kb
  • [2024-05-14 02:54:18]
  • 提交

answer

#include<bits/stdc++.h>
#pragma GCC optimize("trapv")
using namespace std;
const int mod=(int)1e9+7; 
#define endl '\n'
#define all(arr) arr.begin(),arr.end()
#define allr(arr) arr.rbegin(),arr.rend()
#define sz size()
#define int long long
int dis[101][101];
int buysell[101][101];
__int128 dis1[101][101];
int buy[101][1001];
int sell[101][1001];
void iforgor()
{
    int n,m,k;
    cin>>n>>m>>k;
    for(int i=0;i<=n;i++)for(int j=0;j<k;j++)buysell[i][j]=-1e9;
    for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)dis[i][j]=1e14;
    for(int i=1;i<=n;i++)
    {
        for(int j=0;j<k;j++)
        {
            int a,b;
            cin>>a>>b;
            buy[i][j]=a;
            sell[i][j]=b;
        }
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++){
            for(int e=0;e<k;e++)
            {
                if(buy[i][e]==-1||sell[j][e]==-1)continue;
                buysell[i][j]=max(buysell[i][j],sell[j][e]-buy[i][e]);
            }
        }
    }
    for(int i=0;i<m;i++)
    {
        int a,b,c;
        cin>>a>>b>>c;
        dis[a][b]=c;
    }
    for(int kk=1;kk<=n;kk++)
        for(int i=1;i<=n;i++)
            for(int j=1;j<=n;j++)
                dis[i][j]=min(dis[i][j],dis[i][kk]+dis[kk][j]);
    int ans=0;
    int l=1,r=2e9;
    int ez=0;
    while(l<=r)
    {
        __int128 mid=(l+r)/2;
        bool negcyc=false;
        for(int i=1;i<=n;i++)
            for(int j=1;j<=n;j++)
                dis1[i][j]=1e14; 
        for(int i=1;i<=n;i++)
            for(int j=1;j<=n;j++)
                dis1[i][j]=(__int128)mid*(__int128)dis[i][j]-(__int128)buysell[i][j];
        for(int kk=1;kk<=n;kk++)        
            for(int i=1;i<=n;i++)
                for(int j=1;j<=n;j++)
                    dis1[i][j]=min(dis1[i][j],dis1[i][kk]+dis1[kk][j]);
        for(int i=1;i<=n;i++)if(dis1[i][i]<=0)negcyc=true,ez=i;
        if(negcyc)
        {
            ans=mid;
            l=mid+1;
        }
        else r=mid-1;
    }
    cout<<ans<<endl;
}   
signed main()
{
    ios_base::sync_with_stdio(false);   
    cin.tie(NULL);   
    int t=1;
    // cin>>t;
    while(t--)iforgor();
}   

Details

Tip: Click on the bar to expand more detailed information

Subtask #1:

score: 0
Wrong Answer

Test #1:

score: 0
Wrong Answer
time: 89ms
memory: 5496kb

input:

100 181 1000
553730496 158361961 892706912 178296397 743382683 297380306 641674485 99624440 917350062 18856036 844421978 187895310 648680590 312745394 560991872 402321479 712754581 166489560 776432653 57402415 554268728 511597509 861517186 541462029 843246768 457630601 923371196 521104850 557772066 ...

output:

0

result:

wrong answer 1st lines differ - expected: '1', found: '0'

Subtask #2:

score: 0
Wrong Answer

Test #14:

score: 21
Accepted
time: 9ms
memory: 4428kb

input:

50 50 20
1000000000 94476 1000000000 75837 1000000000 27079 1000000000 129004 1000000000 100830 1000000000 98560 1000000000 99302 1000000000 65993 30410 1 1000000000 66183 1000000000 89148 1000000000 21236 1000000000 11935 1000000000 53895 1000000000 126490 1000000000 104741 1000000000 78615 1000000...

output:

1003

result:

ok single line: '1003'

Test #15:

score: 0
Accepted
time: 11ms
memory: 4420kb

input:

50 50 10
-1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1
-1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 339508586 -1 -1 -1
-1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1
-1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1
-1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1...

output:

15782746

result:

ok single line: '15782746'

Test #16:

score: 0
Accepted
time: 11ms
memory: 4248kb

input:

50 50 50
-1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 12 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 10000 10000 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ...

output:

203

result:

ok single line: '203'

Test #17:

score: 0
Accepted
time: 10ms
memory: 4160kb

input:

48 48 50
-1 -1 10002 10002 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 10 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ...

output:

212

result:

ok single line: '212'

Test #18:

score: -21
Wrong Answer
time: 15ms
memory: 4248kb

input:

50 50 50
662985743 94901609 899384837 65628166 673532122 180059305 627752310 127592351 824072744 87540640 507122543 377977048 635262419 187630987 838541684 187757801 577199874 274873255 694303855 184204318 853356130 175381182 520003147 69588361 734732717 178931356 807461406 173458145 548944353 44467...

output:

22815785

result:

wrong answer 1st lines differ - expected: '24700682', found: '22815785'

Subtask #3:

score: 0
Runtime Error

Test #37:

score: 0
Runtime Error

input:

100 243 1000
969713863 380451398 977287381 546839551 578242281 267067963 834635238 316438277 806980243 189648353 779415475 453867771 741678190 352485450 473763928 190177433 687118672 377243148 644333594 197290749 949048287 436673078 690006797 180711316 714366028 387342721 980055654 198167471 8873988...

output:


result:


Subtask #4:

score: 0
Skipped

Dependency #1:

0%