수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

합병정렬좀 도와주세요 ㅠㅠ

지우개

2023.04.01


질문 제목 : 합병정렬 ㅠ아래 스샷처럼 합병정렬도 정렬되는 과정을 출력을 해야하는데요
출력할방법을 모르겟네요 ㅠ 함수 출력도 안대구 뭐가문제인지 잘모르겟어요
또 메인 함수에서 와일로 무한루프를 돌게하고 선택 버블 합병 3개 다출력후 프로그램을 종료시키려고하는데 그것도 잘안되네요 ㅠ
도와주세요!!ㅠㅜ

질문 내용 :

#include stdio.h
#include stdlib.h
#define max_size 8
//스왑(위치 값 바꾸기)
#define swap(x, y, t) ( (t)=(x), (x)=(y), (y)=(t) )
//
int n;
int list[max_size] = { 8, 1, 6, 7, 3, 5, 2, 4 };//배열 선언후 초기값
//
//선택 정렬(selection sort)
void selection_sort(int list[], int n)
{
int i, j, k, least, temp;
printf(\n\n******선택정렬******\n);
for(i=0; in-1; i++) {
least = i;
for(j=i+1; jn; j++) // 최소값 탐색
if(list[j]list[least]) least = j;
swap(list[i], list[least], temp);

//선택정렬 단계별로 출력
for(k=0; kn; k++){
printf(%d ,list[k]);
}
printf(\n);
}
printf(****선택정렬후↓****\n);
for(i=0; in; i++){
printf(%d ,list[i]);
}
printf(\n);
}
//
//버블정렬(bubble_sort)
void bubble_sort(int list[], int n)
{
int i,j, k, temp;
printf(\n\n******버블정렬******\n);
for(i=n-1; i0; i--){
for(j=0; ji; j++)
/* 앞뒤의 레코드를 비교한 후 교체 */
if(list[j]list[j+1])
swap(list[j], list[j+1], temp);

//버블정렬 단계별로 출력
for(k=0; kn; k++){
printf(%d ,list[k]);
}
printf(\n);
}
printf(****버블정렬후↓****\n);
for(i=0; in; i++){
printf(%d ,list[i]);
}
printf(\n);
}
//
//합병정렬(merge_sort)
int sorted[max_size];
/* i는 정렬된 왼쪽리스트에 대한 인덱스
j는 정렬된 오른쪽리스트에 대한 인덱스
k는 정렬될 리스트에 대한 인덱스 */
void merge(int list[], int left, int mid, int right)
{
int i, j, k, l;
i=left;
j=mid+1;
k=left;

/* 분할 정렬된 list의 합병 */
while(i=mid && j=right){
if(list[i]=list[j])
sorted[k++] = list[i++];
else
sorted[k++] = list[j++];
}
if(imid)/* 남아 있는 레코드의 일괄 복사 */
for(l=j; l=right; l++)
sorted[k++] = list[l];
else/* 남아 있는 레코드의 일괄 복사 */
for(l=i; l=mid; l++)
sorted[k++] = list[l];
/* 배열 sorted[]의 리스트를 배열 list[]로 재복사 */
for(l=left; l=right; l++)
list[l] = sorted[l];
}
//
void merge_sort(int list[], int left, int right)
{
int mid,a;
printf(\n\n******버블정렬******\n);
if(leftright){
mid = (left+right)/2; /* 리스트의 균등 분할 */
merge_sort(list, left, mid); /* 부분 리스트 정렬 */
merge_sort(list, mid+1, right); /* 부분 리스트 정렬 */
merge(list, left, mid, right); right); /* 합병 */
}
printf(****합병정렬후↓****\n);
for(a=0; an; a++){
printf(%d ,list[a]);
}
printf(\n);
}
//
void main()
{
int i,a;
n = max_size;

//정렬이 안된 값
printf(-----정렬 전 \n);
for(i=0; in; i++){
printf(%d ,list[i]);
}

printf(\n\n어떤 정렬을 하실껀가요?\n);
printf([1]선택정렬 [2]버블정렬 [3]합병정렬 : );
scanf(%d, &a);
while(1){
if(a==1)
//---선택 정렬---
//선택정렬 함수 호출
selection_sort(list, n);
else if(a==2)
//---버블 정렬---
//선택정렬 함수 호출
bubble_sort(list, n);
else if(a==3)
//---합병 정렬---
//선택정렬 함수 호출
merge_sort(list,0,n);
}
printf(\n);
}

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

번호 제 목 글쓴이 날짜
2700150 꼭좀 도와주세요ㅠㅠㅠ 호습다 2025-07-02
2700095 연산문제...질문... 오빤테앵겨 2025-07-01
2700070 while문 , 3의배수 출력하는 프로그램좀 짜주세욤. 횃불 2025-07-01
2700041 초보인데요 ㅎ 배열안에 배열을 집어넣을수 있나요?? 헛장사 2025-07-01
2700012 배열// (1) 전갈자리 2025-07-01
2699895 무한루프에 빠집니다.!! 해결좀부탁드려요 (10) 선아 2025-06-30
2699842 질문을 너무 많이 하네여.....죄송.... (2) 해님꽃 2025-06-29
2699816 오류 질문입니다.. (1) 해비치 2025-06-29
2699763 질문입니다 ! 꼭 좀 도와주세요ㅠㅠ (2) 미라 2025-06-28
2699555 c언어 다항식을 입력을 했는데 왜 출력이 안될까요? 피스케스 2025-06-27
2699528 C언어 포인터연산 질문입니다. (3) 안녕나야 2025-06-26
2699476 끌어올림;;달력 짜봤는데요 이 소스 줄일 수 있나요? - 스샷첨부 (2) 클라우드 2025-06-26
2699444 [좀 급함] system("explorer [주소] ") 문에 변수를 사용할 수 있나요? 알 2025-06-26
2699415 파일//read//와 배열 아란 2025-06-25
2699386 구조체 안에 일부분만 char 배열에 복사하려면 어떻게 해야하나요? (1) 미즈 2025-06-25
2699361 연결리스트 정렬하는 부분에 대해서 질문 드립니다 아이처럼 2025-06-25
2699304 [기초]아직 안주무시는분 계신가요..?포인터배열? 좀 도와주세요. 놀리기 2025-06-24
2699272 printf() 함수이용해서 프로그램 만들기 질문요! (5) 다가 2025-06-24
2699221 PUSH와 POP코드를 더 간단하게 어떻게 해야할까요? 파라미 2025-06-24
2699192 설치오류가 자꾸 나요 한번봐주세여~ (1) 소녀틳향기 2025-06-23
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com