Merge_sort(병합정렬)질문입니다. 잘아시는분들 답변좀
물
재가 병합 정렬에 대해 배운 이론을 갖고 소스를 함 구현해 보려고 했는데 아무래도 재귀함수를 다향하게 사용해본 경험이 별로 없어서 힘들더라구요 그래서 인터넷 도움을 받아서 일단 비교하여 배열에 저장하는 방법을 보고 만들었는데 작동은 됩니다. 근데
프로그램이 어떻게 돌아가여 저렇게 출력이 되는지는 아무래 그림을 그리고 생각을 해봐도 어떤순서대로 함수를 다시 호출하고 병합하는지 이해하기가 힘드내요...잘 설명해주실수 있는분 설명좀 부탁드릴깨요 -_ㅠ
빨간색으로 줄친부분이 구체적으로 이해가 안갑니다.
#includestdio.h
void merge(int data[], int p, int r);
void merge(int data[], int p, int q, int r);
void main()
{
int i,p=0,r=10,data[]={31,3,65,73,8,11,20,29,48,15};
merge(data, p, r);
/*for(i=0; i10; i++){
printf(%d,, data[i]);
}*/}
void merge(int data[], int p, int r)
{
int q=0;
if(pr){
q=(p+r)/2;
merge(data, p,q); //왼쪽
merge(data, q+1,r); //오른쪽
merge(data, p, q, r); //병합정렬
}
}
void merge(int data[], int p, int q, int r)
{
int tmp[11]={0};
int lf=p; //왼쪽처음
int ll=q; //왼쪽끝
int rf=q+1; //오른쪽첨
int rl=r; //오른쪽끝
int index=lf; //정렬할 인덱스처음
for (; index = rl; index++){
if (lf = ll && rf rl || data[lf] data[rf])
tmp[index] = data[lf++];
else
tmp[index] = data[rf++];
}
for(index=p; index=r; index++){
data[index]=tmp[index];
}
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692483 | C언어 함수, Header | 떠나간그놈 | 2025-04-23 |
2692451 | 이 문제좀 풀어주세요 ^^ | 게자리 | 2025-04-23 |
2692424 | 2차원배열 자료입력질문이요! (1) | 똘끼 | 2025-04-22 |
2692401 | 유닉스안에서 C언어를 이용한 명함 만들기 입니다; 이해안가는 부분이있네요 | 2gether | 2025-04-22 |
2692374 | 고수님들 댓글 마니부탁해요!!! (2) | 엄지 | 2025-04-22 |
2692343 | scnaf에 자꾸 선언을 참조하라는데;; (8) | 도래 | 2025-04-22 |
2692282 | 도스상에서 생성된 exe파일에 press~ 뜨게 하기 (4) | 회사원 | 2025-04-21 |
2692256 | scanf("%*c"); ㅠㅠ 고수님들 | 거북이 | 2025-04-21 |
2692230 | 하노이탑 질문입니다. (1) | 미쁘다 | 2025-04-21 |
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |