QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#662773#9408. Hero of the KingdomTheShuMo#AC ✓198ms3780kbC++142.3kb2024-10-21 10:13:502024-10-21 10:13:50

Judging History

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

  • [2024-10-21 10:13:50]
  • 评测
  • 测评结果:AC
  • 用时:198ms
  • 内存:3780kb
  • [2024-10-21 10:13:50]
  • 提交

answer

#include<bits/stdc++.h>
#define fo(s) freopen(s".in","r",stdin),freopen(s".out","w",stdout)
#define rep(i,l,r) for(ll i(l),i##end(r);i<=i##end;++i)
#define per(i,r,l) for(ll i(r),i##end(l);i>=i##end;--i)
#define dbg(x) cerr<<#x<<" "<<x<<'\n';
#define ll __int128
#define gc getchar
#define pc putchar
using namespace std;
namespace WrongIO
{
	#define Ts template<typename Ty,typename... Ar>
	#define Tp template<typename Ty>
	Tp Ty wmax(Ty a,Ty b){return a>=b? a:b;}
	Tp Ty wmin(Ty a,Ty b){return a<=b? a:b;}
	Tp void read(Ty &x){x=0;Ty opt=1;char c=gc();while(!isdigit(c)&&c!='-')c=gc();if(c=='-')opt=-1,c=gc();while(isdigit(c))x=(x<<3)+(x<<1),x+=c-'0',c=gc();x*=opt;return;}
	Tp void write(Ty x){short OI_USE[150],OI_top=0;if(x<=0) if(x==0)pc('0');else pc('-'),x*=-1;while(x)OI_USE[++OI_top]=x%10,x/=10;while(OI_top--)pc(OI_USE[OI_top+1]+'0');return;}
    void writec(char c[]){int len=strlen(c);for(int i=0;i<len;i++)pc(c[i]);}
    void writes(string s){int len=s.length();for(int i=0;i<len;i++)pc(s[i]);}
    void readc(char &c,int l,int r){c=gc(); while(c!=EOF&&(c<l||c>r)) c=gc();}
    void readc(char &c,char val){c=gc();while(c!=EOF&&c!=val) c=gc();}
    void readc(char val){char c;c=gc();while(c!=EOF&&c!=val) c=gc();}
    void readls(string &s){char c=gc();while(c!='\n') s.push_back(c),c=gc();}
    Ts void read(Ty &x,Ar &...y) {read(x),read(y...);}
    Tp void writeln(Ty x) {write(x),pc('\n');}
    Tp void writesp(Ty x) {write(x),pc(' ');} 
    #undef Ts
	#undef Tp
} using namespace WrongIO;
ll T;
ll p,a,b,q,c,d,m,t;
void solve()
{
	read(p,a,b,q,c,d,m,t);
	while(t)
	{
		ll num=m/p;
		if(num==0) break;
		ll k=(p-m%p)/(q-p)/num;
		if((p-m%p)%((q-p)*num)!=0) k++;
		if(t>=k*(num*(a+c)+b+d))
		{
			t-=k*(num*(a+c)+b+d);
			m+=k*num*(q-p);
		}else{
//			if(k!=0) k--;
//			t-=k*(num*(a+c)+b+d);
//			m+=k*num*(q-p);
			ll qk=t/(num*(a+c)+b+d);
			t-=qk*(num*(a+c)+b+d);
			m+=qk*num*(q-p);
			
			t-=b+d;
			ll ksk=(t/(a+c)); if(ksk<0) ksk=0;
			m+=(q-p)*ksk;
			break;
		}
//		if(m/p==0) break;
//		t-=b+d;
//		if(t<=0) break;
//		if(t>=(m/p)*(a+c))
//		{
//			t-=(m/p)*(a+c);
//			m+=(q-p)*(m/p);
//		}
//		else
//		{
//			ll ksk=t/(a+c);
//			m+=ksk*(q-p);
//			break;
//		}
	}
	writeln(m);
}
int main()
{
	read(T);
	while(T--) solve();
}

这程序好像有点Bug,我给组数据试试?

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 3504kb

input:

3
5 2 3
8 1 5
14 36
5 2 0
8 1 3
17 6
100 1 0
10000 1 0
99 100000

output:

32
20
99

result:

ok 3 lines

Test #2:

score: 0
Accepted
time: 1ms
memory: 3592kb

input:

500
252 34074578 3386884
628907 1207868 18
279 125908043
17268783 50414369 277106
17532337 45 0
17268784 4606
5506 3465964 19
5543 4786900 7
8109756 50825
23718927 66546966 0
23718931 96 0
117090491 99433206
537909 33389755 4
537910 1362118 0
538731 3
47 117 17333
1724743 7699 402536
79710763 684241...

output:

1886244
17268784
8109756
117090495
538731
136625731
586
25929035
17864
7905961573
38782804
670869825
16635
88588674
4502
3995
6379706119
1070452
134333292
495166
324797075
156
598405696216
53895
3503164
4727693
124349483
3764139838369
2840566939118
85930522
4319452
996195
54156125533
32693
216299285...

result:

ok 500 lines

Test #3:

score: 0
Accepted
time: 1ms
memory: 3780kb

input:

500
9859 96 66
18107 8 30
9950 322595515
6685 7 72
14282 47 17
710156469 985188306
786 32 8
2933 21 57
2530 475357775
1535 61 92
9610 100 90
6051 234173340
235 86 81
5512 27 68
9835 714622972
687 56 37
3582 70 100
629389147 226582349
9168 61 11
12755 16 97
664916091 247483035
2739 64 90
5897 44 9
38...

output:

25584109990
139311465421
19256441236
11744948201
33372232765
5835380797
12193720615
13079297133
19440097830
56779063033
331648541482
2723772225
237117790
10437118404
395216971
31345418497
32698954033
11916385660
17791542518
6032738252
36336942872
32227281718
49751088535
16843534938
33842489055
27371...

result:

ok 500 lines

Test #4:

score: 0
Accepted
time: 1ms
memory: 3620kb

input:

500
31708734 1 0
31708735 1 0
31708734 1000000000
71574353 1 0
71574354 1 0
71574353 1000000000
46622902 1 0
46622903 1 0
46622902 1000000000
76021915 1 0
76021916 1 0
76021915 1000000000
89054722 1 0
89054723 1 0
89054722 1000000000
88299900 1 0
88299901 1 0
88299900 1000000000
82784529 1 0
8278453...

output:

531708734
571574353
546622902
576021915
589054722
588299900
582784529
582129869
551025857
568544853
526715316
569267326
559579715
530370885
527159843
555075715
541540909
527571311
523397790
552716884
520753977
538383098
589249550
571463305
564892769
550316979
598655625
576520305
522745720
540557074
...

result:

ok 500 lines

Test #5:

score: 0
Accepted
time: 1ms
memory: 3512kb

input:

500
1 1 8
8 1 5
30 469496529
10 10 4
17 8 8
74 14
6 6 1
16 10 2
73 196513513
9 10 8
19 8 3
21 48
9 8 6
17 5 3
5 57
5 3 1
12 5 7
30 98
6 2 8
9 8 4
38 9
2 8 4
4 1 8
92 767092959
8 8 8
17 3 7
99 33
9 9 7
19 7 6
87 81
4 7 2
10 9 10
32 25561344
5 3 7
13 1 0
55 64
4 1 6
13 1 10
23 869480511
7 2 1
11 2 1
8...

output:

1643237472
74
122820983
41
5
100
38
170465138
108
127
9585470
151
3912661094
722399361
92971888
114793872
81501035
2
38095692
118
35
20
36
53133573
102
68
49549067
40
130361099
115493267
255885870
92
17
46571659
97
78
7783122
302931422
133654535
34001068
100
3462678
48960994
160399289
447095016
1058...

result:

ok 500 lines

Test #6:

score: 0
Accepted
time: 197ms
memory: 3532kb

input:

500
999967811 1 0
1000000000 1 0
999967811 1000000000
999969915 1 0
1000000000 1 0
999969915 1000000000
999967473 1 0
1000000000 1 0
999967473 1000000000
999969851 1 0
1000000000 1 0
999969851 1000000000
999969545 1 0
1000000000 1 0
999969545 1000000000
999967977 1 0
1000000000 1 0
999967977 1000000...

output:

16095499967811
15043499969915
16264499967473
15075499969851
15228499969545
16012499967977
16205999967590
15347499969307
15977999968046
16261499967479
16134999967732
16436499967129
16170999967660
15717499968567
15267499969467
16202999967596
16078999967844
15677999968646
15922999968156
15056999969888
...

result:

ok 500 lines

Test #7:

score: 0
Accepted
time: 198ms
memory: 3508kb

input:

500
32242 1 0
32243 1 0
32242 1000000000
30507 1 0
30508 1 0
30507 1000000000
30104 1 0
30105 1 0
30104 1000000000
31357 1 0
31358 1 0
31357 1000000000
31645 1 0
31646 1 0
31645 1000000000
32632 1 0
32633 1 0
32632 1000000000
31676 1 0
31677 1 0
31676 1000000000
32647 1 0
32648 1 0
32647 1000000000
...

output:

500032242
500030507
500030104
500031357
500031645
500032632
500031676
500032647
500030881
500031392
500032808
500032799
500032389
500032220
500030030
500031592
500031157
500031354
500031417
500032692
500032050
500031094
500030773
500030191
500031507
500032455
500032786
500032597
500031281
500030551
...

result:

ok 500 lines

Extra Test:

score: 0
Extra Test Passed