提交记录 3822


用户 题目 状态 得分 用时 内存 语言 代码长度
skylee noi18b. 【NOI2018】冒泡排序 Time Limit Exceeded 12 1 s 9384 KB C++ 1.73 KB
提交时间 评测时间
2018-07-18 18:37:28 2020-07-31 21:46:35
#include<cstdio>
#include<cctype>
#include<algorithm>
inline int getint() {
	register char ch;
	while(!isdigit(ch=getchar()));
	register int x=ch^'0';
	while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
	return x;
}
typedef long long int64;
const int N=6e5+1;
const int mod=998244353;
int n,p[N],fac[N],ifac[N];
class FenwickTree {
	private:
		int val[N];
		int lowbit(const int &x) const {
			return x&-x;
		}
	public:
		void reset() {
			std::fill(&val[1],&val[n]+1,0);
		}
		void modify(int p) {
			for(;p<=n;p+=lowbit(p)) {
				val[p]++;
			}
		}
		int query(int p) const {
			int ret=0;
			for(;p;p-=lowbit(p)) {
				ret+=val[p];
			}
			return ret;
		}
};
FenwickTree t;
inline int C(const int &n,const int &m) {
	return (int64)fac[n]*ifac[m]%mod*ifac[n-m]%mod;
}
void exgcd(const int &a,const int &b,int &x,int &y) {
	if(!b) {
		x=1,y=0;
		return;
	}
	exgcd(b,a%b,y,x);
	y-=a/b*x;
}
inline int inv(const int &x) {
	int ret,tmp;
	exgcd(x,mod,ret,tmp);
	return (ret%mod+mod)%mod;
}
int main() {
	for(register int i=fac[0]=1;i<N;i++) {
		fac[i]=(int64)fac[i-1]*i%mod;
	}
	ifac[N-1]=inv(fac[N-1]);
	for(register int i=N-1;i;i--) {
		ifac[i-1]=(int64)ifac[i]*i%mod;
	}
	for(register int T=getint();T;T--) {
		n=getint();
		bool increase=true;
		for(register int i=1;i<=n;i++) {
			p[i]=getint();
			if(p[i]!=i) increase=false;
		}
		if(increase) {
			printf("%d\n",int(((int64)C(n*2,n)*inv(n+1)%mod-1+mod)%mod));
			continue;
		}
		int ans=0;
		while(std::next_permutation(&p[1],&p[n]+1)) {
			int sum=0;
			for(register int i=1;i<=n;i++) {
				sum+=std::abs(i-p[i]);
			}
			sum/=2;
			t.reset();
			int tmp=0;
			for(register int i=n;i>=1;i--) {
				tmp+=t.query(p[i]);
				t.modify(p[i]);
			}
			if(tmp==sum) (++ans)%=mod;
		}
		printf("%d\n",ans);
	}
	return 0;
}

CompilationN/AN/ACompile OKScore: N/A

Testcase #114.775 ms4 MB + 616 KBAcceptedScore: 4

Testcase #260.241 ms4 MB + 616 KBAcceptedScore: 4

Testcase #3751.91 ms4 MB + 616 KBAcceptedScore: 4

Testcase #41 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #51 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #61 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #71 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #81 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #91 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #101 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #111 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #121 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #131 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #141 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #151 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #161 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #171 s4 MB + 612 KBTime Limit ExceededScore: 0

Testcase #181 s4 MB + 616 KBTime Limit ExceededScore: 0

Testcase #191 s4 MB + 616 KBTime Limit ExceededScore: 0

Testcase #201 s4 MB + 616 KBTime Limit ExceededScore: 0

Testcase #211 s6 MB + 644 KBTime Limit ExceededScore: 0

Testcase #221 s7 MB + 140 KBTime Limit ExceededScore: 0

Testcase #231 s7 MB + 1012 KBTime Limit ExceededScore: 0

Testcase #241 s8 MB + 852 KBTime Limit ExceededScore: 0

Testcase #251 s9 MB + 168 KBTime Limit ExceededScore: 0


Judge Duck Online | 评测鸭在线
Server Time: 2026-04-17 23:33:14 | Loaded in 1 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠