제출 #342616

#제출 시각아이디문제언어결과실행 시간메모리
342616ogibogi2004Table Tennis (info1cup20_tabletennis)C++14
58 / 100
3077 ms3296 KiB
#include<bits/stdc++.h>
using namespace std;
const int MAXN=150002;
int n,k;
int a[MAXN];
set<int>checked_sums;
int main()
{
	ios_base::sync_with_stdio(false);
	cin.tie(NULL);cout.tie(NULL);
	cin>>n>>k;
	for(int i=1;i<=n+k;i++)
	{
		cin>>a[i];
	}
	for(int i=1;i<=k+1&&i<=n+k;++i)
	{
		for(int j=n+k;i-1+(n+k-j)<=k&&j>i;--j)
		{
			//cout<<i<<" "<<j<<endl;
			int sum=a[i]+a[j];
			if(checked_sums.find(sum)!=checked_sums.end())continue;
			int l=i,r=j,cnt=0;
			for(;;)
			{
				if(l==r||l>r)break;
				if(a[l]+a[r]==sum)
				{
					++cnt;++l;--r;
				}
				else
				{
					if(a[l]+a[r]>sum)--r;
					else ++l;
				}
			}
			if(cnt>=n/2)
			{
				vector<int>v1,v2;
				l=i,r=j;
				for(;;)
				{
					if(l==r||l>r)break;
					if(v1.size()+v2.size()==n)break;
					if(a[l]+a[r]==sum)
					{
						v1.push_back(a[l]);
						v2.push_back(a[r]);
						l++;
						r--;
					}
					else
					{
						if(a[l]+a[r]>sum)r--;
						else l++;
					}
				}
				reverse(v2.begin(),v2.end());
				for(auto xd:v1)cout<<xd<<" ";
				for(auto xd:v2)cout<<xd<<" ";
				cout<<endl;
				return 0;
			}
			checked_sums.insert(sum);
		}
	}
return 0;
}

컴파일 시 표준 에러 (stderr) 메시지

tabletennis.cpp: In function 'int main()':
tabletennis.cpp:44:28: warning: comparison of integer expressions of different signedness: 'std::vector<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   44 |      if(v1.size()+v2.size()==n)break;
      |         ~~~~~~~~~~~~~~~~~~~^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...