【骗特殊性质】最简单的40pts代码
查看原帖
【骗特殊性质】最简单的40pts代码
1090220
_Flora_楼主2024/10/27 11:08
#include <bits/stdc++.h>
using namespace std;

int d[100001],v[100001],a[100001],p[100001];

void solve()
{
	int i,n,m,L,V,flag=0,sum=0;
	
	cin>>n>>m>>L>>V;
	
	for(i=1;i<=n;i++)
	{
		cin>>d[i]>>v[i]>>a[i];
		
		if(a[i]!=0)
		{
			flag=1;
		}
	}
	
	for(i=1;i<=m;i++)
	{
		cin>>p[i];
	}
	
	if(flag==0)
	{
		for(i=1;i<=n;i++)
		{
			if(d[i]<=p[m] && v[i]>V)
			{
				sum++;
			}
		}
		
		if(sum==0)
		{
			cout<<0<<" "<<m<<endl;
		}
		else
		{
			cout<<sum<<" "<<m-1<<endl;
		}
	}
	else
	{
		for(i=1;i<=n;i++)
		{
			if(d[i]<=p[m] && sqrt((p[m]-d[i])*2*a[i]+pow(v[i],2))>V)
			{
				sum++;
			}
		}
		
		if(sum==0)
		{
			cout<<0<<" "<<m<<endl;
		}
		else
		{
			cout<<sum<<" "<<m-1<<endl;
		}
	}
} 
int main()
{
	int T;
	
	cin>>T;
	
	while(T--)
	{
		solve();
	}
	
	return 0;
}

5min左右完成,能稳拿40分吗

2024/10/27 11:08
加载中...