제가 작성한 문제 풀이. 반례 좀 부탁 드립니다.
글쓴이: 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
댓글 달기