힙소트 비슷한 문제 질문입니다
아연
질문 제목 : 힙소트 응용해서 푸는 문제인데..... 아래로 내려가는게 작동을 안해요;;;질문 요약 :힙소트가 이상합니다;;;질문 내용 : #includestdio.h
int n,nn;
int d[50001],heap[50001];
int main()
{
int i,j,h_i,temp,sum=0,k;
freopen(input.txt,r,stdin);
freopen(output.txt,w,stdout);
scanf(%d,&n);
for(i=1;i=n;i++){
scanf(%d,&d[i]);
}
for(i=1;i=n;i++){
heap[i]=d[i];
h_i=i;
while(1){
if(h_i==1) break;
if(heap[h_i]heap[h_i/2]){
temp=heap[h_i];
heap[h_i]=heap[h_i/2];
heap[h_i/2]=temp;
h_i/=2;
}
else break;
}
}
heap[0]=-1;
for(i=1;i=n-1;i++){
nn=n-i;
if(heap[2]heap[3]){
heap[3]=heap[1]+heap[3];
sum+=heap[3];
h_i=3;
}
else {
heap[2]=heap[1]+heap[2];
sum+=heap[2];
h_i=2;
}
while(1){
if (h_i*2=n) break;
if (h_i*2+1=nn){
if (heap[h_i*2]heap[h_i*2+1]) k=h_i*2+1;
else k=h_i*2;
}
else k=h_i*2;
if (heap[h_i]heap[k]){
int tmp=heap[h_i];
heap [ h_i ]=heap [k];
heap [k]=tmp;
h_i=k;
}
else break;
}
/* heap[1]=99999;
h_i=1;
while(1){
if(h_i/2=n) break;
if (heap[h_i*2]heap[h_i*2+1]) k=h_i*2+1;
else k=h_i*2;
if (heap[h_i]=heap[k]){
int tmp=heap[h_i];
heap [h_i]=heap [k];
heap [k]=tmp;
h_i=k;
}
else break;
}*/
for(j=1;j=n;j++) if(heap[j]==0) heap[j]=99999;
}
printf(%d,sum);
return 0;
}주석처리한부분이 이상한듯 싶어요.... 제일 마지막노드가 위로 못올라가네요....
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2695033 | 답변좀요ㅠㅠ (1) | 비사벌 | 2025-05-16 |
2695010 | C++의 STL은 왜 굳이 템플릿화 시켜서 라이브러리를 만드나요? (초보수준의 질문..) (2) | 엘보어 | 2025-05-16 |
2694958 | 로직이 변한다는 것에 대해서 궁금합니다. | 튼동 | 2025-05-16 |
2694929 | 열혈강의 25-2 두번째 문제 질문 | 지우개 | 2025-05-15 |
2694900 | dequeue 에서 리턴값 프린트 방법알려주세요 오늘 12시까지 대화방에 있습니다 도와주세요 | 미투리 | 2025-05-15 |
2694854 | 절대값을 구할때 (2) | 그녀는귀여웠다 | 2025-05-15 |
2694827 | 이제 어떻게 공부해야할지 모르겠네요 | 새얀 | 2025-05-14 |
2694778 | 순열 계산요. | 맛조이 | 2025-05-14 |
2694754 | ShowWindow 함수를 이용하려 하는데 질문있습니다. (2) | 파도 | 2025-05-14 |
2694731 | 리눅스 커널의 시작점 질문 | 미르 | 2025-05-13 |
2694702 | 이거 뭐가문제인가요 코드수정좀 (3) | 맑은 | 2025-05-13 |
2694675 | C언어 후위표기를 중위표기로 | 앨런 | 2025-05-13 |
2694646 | 안녕하세요 파일 합치기 함수! (1) | 연블루 | 2025-05-13 |
2694618 | 잘몰라서 설명부탁드립니다. scanf 관련 (3) | 파라 | 2025-05-12 |
2694590 | 이 코드가 뭐하는 코드일까요? #2 | 빵순 | 2025-05-12 |
2694559 | 동적할당으로 배열(2차원열)을 만드는데 있어 그걸 함수화시키는데... (1) | 늘솔길 | 2025-05-12 |
2694532 | 네트워크에 관하여... (4) | 황소자리 | 2025-05-12 |
2694503 | 프로그램 연산 후 바로 종료되는 현상 (6) | Judicious | 2025-05-11 |
2694450 | while문질문입니다. (1) | 허리품 | 2025-05-11 |
2694420 | C언어 질문할게요(유니코드,자료형,버퍼,캐스트연산자) | 은새 | 2025-05-11 |