QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#232391#959. Multiple?AFewSunsAC ✓993ms3568kbC++141.6kb2023-10-30 12:35:192023-10-30 12:35:20

Judging History

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

  • [2023-10-30 12:35:20]
  • 评测
  • 测评结果:AC
  • 用时:993ms
  • 内存:3568kb
  • [2023-10-30 12:35:19]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
namespace my_std{
	#define ll long long
	#define bl bool
	ll my_pow(ll a,ll b,ll mod){
		ll res=1;
		if(!b) return 1;
		while(b){
			if(b&1) res=(res*a)%mod;
			a=(a*a)%mod;
			b>>=1;
		}
		return res;
	}
	ll qpow(ll a,ll b){
		ll res=1;
		if(!b) return 1;
		while(b){
			if(b&1) res*=a;
			a*=a;
			b>>=1;
		}
		return res;
	}
	#define db double
	#define pf printf
	#define pc putchar
	#define fr(i,x,y) for(register ll i=(x);i<=(y);i++)
	#define pfr(i,x,y) for(register ll i=(x);i>=(y);i--)
	#define go(u) for(ll i=head[u];i;i=e[i].nxt)
	#define enter pc('\n')
	#define space pc(' ')
	#define fir first
	#define sec second
	#define MP make_pair
	#define il inline
	#define inf 8e18
	#define random(x) rand()*rand()%(x)
	#define inv(a,mod) my_pow((a),(mod-2),(mod))
	il ll read(){
		ll sum=0,f=1;
		char ch=0;
		while(!isdigit(ch)){
			if(ch=='-') f=-1;
			ch=getchar();
		}
		while(isdigit(ch)){
			sum=sum*10+(ch^48);
			ch=getchar();
		}
		return sum*f;
	}
	il void write(ll x){
		if(x<0){
			x=-x;
			pc('-');
		}
		if(x>9) write(x/10);
		pc(x%10+'0');
	}
	il void writeln(ll x){
		write(x);
		enter;
	}
	il void writesp(ll x){
		write(x);
		space;
	}
}
using namespace my_std;
#define mod 998244353
ll n,k,ans;
int main(){
	n=read();
	k=read();
	ll N=n;
	ans=n;
	for(ll i=2;i*i<=n;i++){
		if(n%i==0){
			ans=ans/i*(i-1);
			while(n%i==0) n/=i;
		}
	}
	if(n>1) ans=ans/n*(n-1);
	ll mul=1;
	fr(i,1,k-1){
		mul=mul*i%mod;
		ans=ans*(N-i)%mod;
	}
	write(ans*inv(mul,mod)%mod);
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 1ms
memory: 3552kb

input:

4 1

output:

2

result:

ok 1 number(s): "2"

Test #2:

score: 0
Accepted
time: 0ms
memory: 3328kb

input:

9 2

output:

48

result:

ok 1 number(s): "48"

Test #3:

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

input:

222222222 222222

output:

851798824

result:

ok 1 number(s): "851798824"

Test #4:

score: 0
Accepted
time: 993ms
memory: 3372kb

input:

998244352 249561088

output:

100663296

result:

ok 1 number(s): "100663296"

Test #5:

score: 0
Accepted
time: 0ms
memory: 3360kb

input:

62 3

output:

54900

result:

ok 1 number(s): "54900"

Test #6:

score: 0
Accepted
time: 0ms
memory: 3568kb

input:

328 42

output:

9805666

result:

ok 1 number(s): "9805666"

Test #7:

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

input:

318 67

output:

603200201

result:

ok 1 number(s): "603200201"

Test #8:

score: 0
Accepted
time: 0ms
memory: 3360kb

input:

1368 16

output:

105422469

result:

ok 1 number(s): "105422469"

Test #9:

score: 0
Accepted
time: 0ms
memory: 3384kb

input:

50715 7550

output:

618459631

result:

ok 1 number(s): "618459631"

Test #10:

score: 0
Accepted
time: 0ms
memory: 3360kb

input:

76973 14799

output:

468374999

result:

ok 1 number(s): "468374999"

Test #11:

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

input:

99380 19487

output:

687640903

result:

ok 1 number(s): "687640903"

Test #12:

score: 0
Accepted
time: 0ms
memory: 3376kb

input:

21790 2731

output:

101785330

result:

ok 1 number(s): "101785330"

Test #13:

score: 0
Accepted
time: 0ms
memory: 3360kb

input:

690640 123082

output:

867724310

result:

ok 1 number(s): "867724310"

Test #14:

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

input:

491216 62882

output:

359870082

result:

ok 1 number(s): "359870082"

Test #15:

score: 0
Accepted
time: 0ms
memory: 3548kb

input:

331430 27658

output:

336996189

result:

ok 1 number(s): "336996189"

Test #16:

score: 0
Accepted
time: 0ms
memory: 3376kb

input:

171644 19051

output:

291982732

result:

ok 1 number(s): "291982732"

Test #17:

score: 0
Accepted
time: 2ms
memory: 3328kb

input:

4480506 212264

output:

613147340

result:

ok 1 number(s): "613147340"

Test #18:

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

input:

436959 48003

output:

451377650

result:

ok 1 number(s): "451377650"

Test #19:

score: 0
Accepted
time: 2ms
memory: 3328kb

input:

6393409 1221473

output:

573934740

result:

ok 1 number(s): "573934740"

Test #20:

score: 0
Accepted
time: 3ms
memory: 3324kb

input:

7381276 607288

output:

895895324

result:

ok 1 number(s): "895895324"

Test #21:

score: 0
Accepted
time: 5ms
memory: 3332kb

input:

7951897 1124478

output:

9197219

result:

ok 1 number(s): "9197219"

Test #22:

score: 0
Accepted
time: 8ms
memory: 3372kb

input:

10822617 1773938

output:

200848469

result:

ok 1 number(s): "200848469"

Test #23:

score: 0
Accepted
time: 7ms
memory: 3352kb

input:

13693337 1629029

output:

390448867

result:

ok 1 number(s): "390448867"

Test #24:

score: 0
Accepted
time: 21ms
memory: 3320kb

input:

21596632 5162607

output:

286800922

result:

ok 1 number(s): "286800922"

Test #25:

score: 0
Accepted
time: 274ms
memory: 3260kb

input:

483262472 68378363

output:

805389870

result:

ok 1 number(s): "805389870"

Test #26:

score: 0
Accepted
time: 302ms
memory: 3260kb

input:

504666092 76509085

output:

487083023

result:

ok 1 number(s): "487083023"

Test #27:

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

input:

828059612 83073089

output:

328505426

result:

ok 1 number(s): "328505426"

Test #28:

score: 0
Accepted
time: 41ms
memory: 3328kb

input:

153208783 10166904

output:

109080048

result:

ok 1 number(s): "109080048"

Test #29:

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

input:

476602303 67863017

output:

414678607

result:

ok 1 number(s): "414678607"

Test #30:

score: 0
Accepted
time: 165ms
memory: 3316kb

input:

498005923 42023403

output:

754443127

result:

ok 1 number(s): "754443127"

Test #31:

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

input:

125144994 23866191

output:

754831055

result:

ok 1 number(s): "754831055"

Test #32:

score: 0
Accepted
time: 18ms
memory: 3356kb

input:

146548614 4304228

output:

655902521

result:

ok 1 number(s): "655902521"