HDOJ 1280 앞 m 큰 수 (폭력 + 빠 른 배수)

1948 단어
앞 m 큰 수
Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 13528    Accepted Submission(s): 4609
Problem Description
Gardon 이 샤 오 쉬 에 게 내 준 그 숙제 기억 나 세 요?(지난번 경기 의 1005) 사실 소 희 는 원래 의 그 시 계 를 되 찾 았 다. 지금 은 그녀의 답 이 정확 한 지 확인 하고 싶 지만 전체 답 은 매우 큰 시계 이다. 소 희 는 네가 답 에서 가장 큰 M 개 수 를 그녀 에 게 알려 주 고 싶 을 뿐이다.  N (N < = 3000) 개의 정 수 를 포함 하 는 서열 을 지정 합 니 다. 각 수 는 5000 을 초과 하지 않 고 두 개 를 더 한 N * (N - 1) / 2 개 와 그 중에서 앞의 M 큰 수 (M < = 1000) 를 구하 고 큰 것 에서 작은 것 으로 배열 합 니 다.
 
Input
입력 은 여러 그룹의 데 이 터 를 포함 할 수 있 습 니 다. 그 중에서 각 그룹의 데 이 터 는 두 줄 을 포함 합 니 다.  첫 번 째 줄 은 N 과 M 입 니 다.  두 번 째 줄 의 N 개 수 는 이 서열 을 나타 낸다.
 
Output
입력 한 각 그룹의 데이터 에 대해 M 개 수 를 출력 하여 결 과 를 표시 합 니 다.출력 은 크 고 작은 순서에 따라 배열 해 야 한다.
 
Sample Input

   
   
   
   
4 4 1 2 3 4 4 5 5 3 6 4

 
Sample Output

   
   
   
   
7 6 5 5 11 10 9 9 8

 
데 이 터 를 보고 특수 처 리 를 해 야 한다 고 생각 했 는데 직접 폭력 을 행사 하면 지나 칠 줄 누가 알 았 겠 는가.
이 문 제 는 배열 이 충분히 커 야 한다. 3000 * (3000 - 1) / 2, 5000000 을 넘 으 면 충분 하 다.
구체 적 인 코드 는 다음 과 같다.
#include<cstdio>
#include<algorithm>
using namespace std;
int sum[5000000];
int a[3050];
int main()
{
	int n,m,i,j,k;
	while(scanf("%d%d",&n,&m)!=EOF)
	{
		for(i=0;i<n;i++)
		   scanf("%d",&a[i]);
		k=0;
		for(i=0;i<n;i++)
		{
			for(j=i+1;j<n;j++)
			{
				sum[k]=a[i]+a[j];
				k++;
			}
		}
		sort(sum,sum+k);
		for(i=k-1;i>k-m;i--)
		  printf("%d ",sum[i]);
		printf("%d
",sum[k-m]); } return 0; }

좋은 웹페이지 즐겨찾기