제가 작성한 문제 풀이. 반례 좀 부탁 드립니다.
글쓴이: canuyes / 작성시간: 목, 2013/07/11 - 5:48오후
현재 ACMICPC 공부 중인 학생입니다.
굉장히 쉬운 문제라고 생각하고 풀었는데, 자꾸 오답이 나오네요..
나름대로 스캐폴딩도 해보고 반례를 찾으려 애써보았지만
딱히 이렇다 할 오답사유를 찾기가 힘듭니다.
문제는
http://www.acmicpc.net/problem/2230 에 있구요.
아래는 제가 분할 정복을 이용해서 짠 소스 코드 입니다.
#include<iostream>
#include<vector>
#include<algorithm>
#define MAX 20000000000
using namespace std;
vector<long long> arr;
long long N,M;
long long smaller(long long x,long long y){if(x<y){return x;}return y;}
long long getMid(long long sp,long long ep){
long long s=(sp+ep)/2,e=s+1,ret=MAX;
while(s>=sp&&e<=ep){
if(arr[e]-arr[s]>=M){ret=arr[e]-arr[s];break;}
else{
if(s==sp){e+=1;}
else if(e==ep){s-=1;}
else{if(arr[s]-arr[s-1]<arr[e+1]-arr[e]){s-=1;}else{e+=1;}}
}}
return ret;
}
long long mkANS(long long sp,long long ep){
long long ret=MAX;
if(sp+1==ep){
if(arr[ep]-arr <M){ret=MAX;}
else{ret=arr[ep]-arr ;}
}
else if(sp==ep){ret=MAX;}
else{
ret=smaller(ret,mkANS(sp,(sp+ep)/2));
ret=smaller(ret,mkANS((sp+ep)/2+1,ep));
ret=smaller(ret,getMid(sp,ep));
}
return ret;
}
int main(void){
long long i,temp;
cin>>N>>M;
for(i=0;i<N;i++){cin>>temp;arr.push_back(temp);}
sort(arr.begin(),arr.end());
cout<<mkANS(0,N-1)<<endl;
return 0;
}답을 여쭙는 것이 아니오라, 제가 코드가 해결하지 못하는 반례를 알고 싶습니다.
Forums:


.
.
입력 8
입력
8 10
1
2
3
4
5
6
7
16
출력
11
정답은 6과 16의 차인 10
댓글 달기