HDOJ 1280 앞 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;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.