QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#623556#5420. InscryptionSoestxWA 320ms3676kbC++23976b2024-10-09 13:04:062024-10-09 13:04:07

Judging History

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

  • [2024-10-09 13:04:07]
  • 评测
  • 测评结果:WA
  • 用时:320ms
  • 内存:3676kb
  • [2024-10-09 13:04:06]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define pll pair<int,int>
#define fi first
#define se second
typedef long long LL;
typedef unsigned long long ull;
int n,m,k;
const int N=1e3+10,M=1e5+10,mod=45989;
int num[N];
int res,cnt;

pll cmp(pll p1,pll p2)
{
	return p1.fi*p2.se>p2.fi*p1.se?p1:p2;
}

void solve() {
	cin>>n;
	m=0;
	int a1=1,a2=1;
	bool flag=1;
	for(int i=1;i<=n;i++)
	{
		int x;
		cin>>x;
		if(x==1) a1++,a2++;
		if(x==-1)
		{
			if(a2>1) a2--;
			else if(m) m--,a1++;
			else flag=0;
		}
		if(x==0) m++;
	}
	if(!flag)
	{
		cout<<"-1"<<endl;
		return;
	}
	pll res={a1,a2};
	for(int i=1;i<=m;i++)
	{
		if(a2+i<=m-i) continue;
		res=cmp(res,{a1+i,a2+i-(m-i)});
	}
	int t=__gcd(res.fi,res.se);
	cout<<res.fi/t<<" "<<res.se/t<<endl;
}


signed main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    int T=1;
    cin>>T;
    while(T--)solve();
    return 0;
}

详细

Test #1:

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

input:

6
7
1 1 1 -1 1 1 -1
4
1 0 -1 0
4
0 -1 -1 0
1
0
2
0 0
1
-1

output:

3 2
3 1
-1
1 1
2 1
-1

result:

ok 6 lines

Test #2:

score: 0
Accepted
time: 320ms
memory: 3632kb

input:

1000000
1
1
1
-1
1
1
1
1
1
1
1
1
1
-1
1
-1
1
0
1
0
1
1
1
0
1
-1
1
0
1
1
1
0
1
1
1
0
1
1
1
0
1
0
1
0
1
1
1
-1
1
1
1
1
1
-1
1
0
1
1
1
0
1
-1
1
0
1
-1
1
1
1
-1
1
0
1
1
1
1
1
-1
1
0
1
-1
1
-1
1
-1
1
-1
1
0
1
0
1
-1
1
0
1
-1
1
0
1
0
1
0
1
0
1
0
1
-1
1
1
1
0
1
0
1
1
1
0
1
-1
1
1
1
1
1
0
1
1
1
1
1
1
1
0
1
...

output:

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 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
-1
1 1
1 1
1 1
1 1
-1
1 1
1 1
1 ...

result:

ok 1000000 lines

Test #3:

score: -100
Wrong Answer
time: 127ms
memory: 3676kb

input:

181249
6
1 0 -1 0 1 0
4
1 -1 -1 -1
8
-1 0 0 0 1 -1 1 1
3
0 1 0
6
1 0 -1 1 -1 0
4
1 -1 -1 -1
9
0 1 0 -1 -1 0 -1 0 1
1
-1
3
0 -1 1
5
0 0 1 -1 1
3
1 -1 0
6
-1 0 0 -1 0 1
8
1 -1 -1 -1 0 1 -1 0
2
0 0
3
-1 1 0
3
0 -1 -1
10
0 1 0 -1 1 1 0 -1 1 0
3
1 0 0
9
1 -1 1 -1 0 -1 0 0 0
3
0 1 0
3
-1 0 0
7
-1 0 -1 -1 ...

output:

4 1
-1
-1
3 2
4 1
-1
3 1
-1
3 2
2 1
2 1
-1
-1
2 1
-1
-1
6 1
3 2
4 1
3 2
-1
-1
-1
-1
1 1
5 4
-1
4 3
1 1
-1
3 2
5 1
1 1
-1
3 2
-1
1 1
-1
2 1
1 1
-1
1 1
-1
1 1
2 1
-1
-1
-1
-1
2 1
5 2
1 1
-1
4 1
-1
-1
1 1
-1
6 1
1 1
-1
2 1
1 1
2 1
-1
5 3
3 1
6 1
-1
2 1
4 3
-1
1 1
-1
3 1
-1
-1
2 1
1 1
2 1
5 2
-1
3 2
4 3...

result:

wrong answer 11th lines differ - expected: '3 2', found: '2 1'