社区讨论

20分求助

P1068[NOIP 2009 普及组] 分数线划定参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@lx8ckv83
此快照首次捕获于
2024/06/10 10:22
2 年前
此快照最后确认于
2024/06/10 14:01
2 年前
查看原帖
CPP
/*****************************************
备注:
******************************************/
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N = 100000 + 10;
const int INF = 0x3f3f3f3f;
int a[N],b[N];
int cnt;
int n,m,k;
int sum=0;
void ans()
{
	cnt=0;
	for(int i=1;i<=n;i++)
	{
		if(cnt==k)
		{
			break;
		}
		else
		{
//			cout<<a[i]<<" "<<b[i]<<endl;
			cnt++;
			sum++;
		}
	}
	for(int i=cnt;i<=n;i++)
	{
		if(b[i]==b[i+1])
		{
//			cout<<a[i+1]<<" "<<b[i+1]<<endl;
			sum++;
		}
		else
		{
			break;
		}
	}
}
signed main()
{
	cin>>n>>m;
	k=floor(m*1.5);
	for(int i=1;i<=n;i++)
	{
		cin>>a[i]>>b[i];
	}
	for(int i=1;i<=n;i++)
	{
		for(int j=i;j<=n;j++)
		{
			if(b[i]<b[j])
			{
				swap(b[i],b[j]);
				swap(a[i],a[j]);
			}
		}
	}
	for(int i=1;i<=n;i++)
	{
		if(b[i]==b[i+1])
		{
			if(a[i]>a[i+1])
			{
				swap(a[i],a[i+1]);
			}
		}
	}
	ans();
	cout<<b[k]<<" "<<sum<<endl;
	int cnt=0;
	for(int i=1;i<=n;i++)
	{
		if(cnt==k)
		{
			break;
		}
		else
		{
			cout<<a[i]<<" "<<b[i]<<endl;
			cnt++;
		}
	}
	for(int i=cnt;i<=n;i++)
	{
		if(b[i]==b[i+1])
		{
			cout<<a[i+1]<<" "<<b[i+1]<<endl;
		}
		else
		{
			break;
		}
	}
	return 0;
}

回复

0 条回复,欢迎继续交流。

正在加载回复...