QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#649385#21608. 行列式Zhou_JKWA 177ms4828kbC++231.3kb2024-10-17 23:15:092024-10-17 23:15:10

Judging History

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

  • [2024-10-17 23:15:10]
  • 评测
  • 测评结果:WA
  • 用时:177ms
  • 内存:4828kb
  • [2024-10-17 23:15:09]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
constexpr int MOD=998244353;
int qpow(int a,int b)
{
    int res=1;
    while(b)
    {
        if(b&1) res=(long long)res*a%MOD;
        a=(long long)a*a%MOD,b>>=1; 
    }
    return res;
}
int getinv(int x)
{
    return qpow(x,MOD-2);
}
int det(vector<vector<int>> &a)
{
    int n=a.size();
    int d=1;
    for(int i=0;i<n;i++)
    {
        int k=i;
        for(int j=i;j<n;j++)
            if(a[k][i])
            {
                k=j;
                break;
            }
        if(!a[k][i])
        {
            d=0;
            break;
        }
        if(i!=k) swap(a[i],a[k]),d=(MOD-d)%MOD;
        d=(long long)d*a[i][i]%MOD;
        int invi=getinv(a[i][i]); 
        for(int j=i+1;j<n;j++)
            a[i][j]=(long long)a[i][j]*invi%MOD;
        for(int j=0;j<n;j++)
            if(j!=i&&a[j][i])
            {
                for(int k=i+1;k<n;k++)
                    a[j][k]=(a[j][k]-(long long)a[i][k]*a[j][i]%MOD+MOD)%MOD;
                a[j][i]=0;
            }
    }
    return d;
}
int main()
{
    int n;
    cin>>n;
    vector<vector<int>>a(n,vector<int>(n));
    for(int i=0;i<n;i++)
        for(int j=0;j<n;j++)
            cin>>a[i][j];
    int res=det(a);
    cout<<res;
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 157ms
memory: 4588kb

input:

494
507979999 844753235 308697058 577366689 725069158 935333779 504374900 25818576 590205152 640101368 622693010 938297920 872742027 301114974 734834637 556531110 842083217 975440662 921805913 100862321 393656903 213191224 795146059 30475198 812681603 711143306 28681751 642978178 605226383 94538558 ...

output:

0

result:

ok 1 number(s): "0"

Test #2:

score: 0
Accepted
time: 144ms
memory: 4820kb

input:

495
460894111 304739937 206829379 20028685 689849252 682804147 71652376 637764473 241844465 687595930 484335000 997257325 91960282 115487884 693010380 928714517 852523641 284836935 938938149 535872486 937318509 488254844 472128573 598325537 448164264 695849563 357631500 18136818 170181462 743369680 ...

output:

0

result:

ok 1 number(s): "0"

Test #3:

score: 0
Accepted
time: 170ms
memory: 4540kb

input:

497
992978625 135595668 100067592 966258349 268720954 208159553 292815949 144239011 616187807 131223525 37398060 618882052 958381768 705910280 516881626 529797552 103092975 818823641 958107310 519034374 618004601 22089192 451439147 102279534 260848112 137489705 538426740 360715737 501827504 91382013...

output:

0

result:

ok 1 number(s): "0"

Test #4:

score: 0
Accepted
time: 141ms
memory: 4508kb

input:

490
606095620 526577618 749002 92727045 713477829 711310002 285285518 869895896 341304078 731510833 992849439 615696835 534048295 7595017 876341982 271404948 821155566 819629263 645006528 353400604 445571584 519466696 285384956 443707571 595516109 578463272 120934435 98086674 434596103 255527559 710...

output:

0

result:

ok 1 number(s): "0"

Test #5:

score: 0
Accepted
time: 156ms
memory: 4572kb

input:

493
605501039 514622351 409922706 338082210 362002781 648772017 642575846 274243185 248202320 136781235 167400754 605189664 755270961 408312147 506733752 367383946 171614465 764280716 805904051 935623612 836937936 801903657 585031190 678293238 426882719 162649698 995973931 820868572 59338187 8307812...

output:

0

result:

ok 1 number(s): "0"

Test #6:

score: 0
Accepted
time: 174ms
memory: 4572kb

input:

494
156648746 154396384 640494892 528756313 434883274 318065816 264440383 659789617 608119380 648104885 725454492 696703871 543030428 663661240 890791532 108201616 428505484 322953840 119811886 691103780 306647414 549862302 176916719 909058872 455464665 307270851 584469329 722629343 875317523 629938...

output:

193142761

result:

ok 1 number(s): "193142761"

Test #7:

score: 0
Accepted
time: 175ms
memory: 4828kb

input:

495
120999146 136987924 40280999 438515315 805152546 234164454 129099933 971852321 983937488 410134225 668461222 574343409 885417013 394300887 86086437 570981511 221329455 57893312 584381871 154204049 738660729 728257729 551666498 540440394 165573287 512342480 452470821 669622703 340240729 965382636...

output:

318551051

result:

ok 1 number(s): "318551051"

Test #8:

score: 0
Accepted
time: 177ms
memory: 4800kb

input:

497
451794314 2028037 288974909 111681588 291303632 155763712 177741457 164199418 280452914 745629015 727272894 383855815 451963117 263419161 854025925 625817844 903511050 636159790 788165373 442332844 275132246 358996390 239303569 23523747 398318281 935986353 142493592 695297770 499848367 7061287 5...

output:

534078061

result:

ok 1 number(s): "534078061"

Test #9:

score: 0
Accepted
time: 170ms
memory: 4800kb

input:

490
504915182 841612625 594492394 841259018 581533827 570061398 728741094 498398681 984147412 115961324 995955785 96920367 943961736 864913388 601212881 773189830 352297773 303107436 986036707 547042133 275735038 251015391 616994042 498027183 5049993 35681904 440260100 11762354 376808026 289984422 1...

output:

734889046

result:

ok 1 number(s): "734889046"

Test #10:

score: 0
Accepted
time: 168ms
memory: 4512kb

input:

493
415335212 437019262 878914770 692819383 929176066 657049555 799637676 179913266 266003265 731227835 705323037 201246867 183631677 270611175 680342740 326297106 21564799 746492922 599870983 729200873 612278331 480645345 574356910 493730340 591363277 253325503 325980362 738703013 254741788 3291237...

output:

859411042

result:

ok 1 number(s): "859411042"

Test #11:

score: -100
Wrong Answer
time: 20ms
memory: 4464kb

input:

494
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 105922509 ...

output:

0

result:

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