수다닷컴

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

합병정렬 시간 차이 문의 입니다.

물고기자리

2023.04.01


질문 제목 :
합병 정렬 소스 문제점좀 알려주세요..(첨부)질문 내용 :
합병정렬을 코딩 하는 중인데요.
동적할당으로 2가지 방법으로 하는데 한가지 방법은 mergesort에서 동적 할당을 하는 방법이고,
두번째 방법(메모리 절약)은 merge하는 부분에서 동적 할당을 하는데요 두 가지 정렬의 시간차이가 너무 많이 나네요..
두번째 방법이 훨씬 느리네요;; 차이점을 좀 알려주세요 ( 십만개 이상 입력을 하였을때)

int main()
{
int datanum;
int *unsorteddata;

printf(정렬 할 숫자의 갯수를 입력 하세요 : );
scanf(%d,&datanum);
srand((unsigned) time(null));
unsorteddata = (int *)malloc(sizeof(int)*(datanum+1));
for(int i = 0; idatanum; i++)
{
unsorteddata[i] = rand()%100;
}
printf(\n);

//merge_sort(unsorteddata,datanum);
merge_inplace_sort(unsorteddata,0,datanum-1);

// 정렬 후 출력 부분
for(int i = 0; idatanum; i++)
{
if(i % 10 == 0) printf(\n);
printf(%d , unsorteddata[i]);
}
printf(\n);

free(unsorteddata); // 메모리 해제
system(pause);
return 1;
}
1번 코드
void merge_sort(int arr[], int n)
{
int h = n/2;
int m = n-h;
int *left,*right;
int i,j;

if(n1)
{
left = (int *)malloc((h-1)*sizeof(int));
right = (int *)malloc((m-1)*sizeof(int));
for(i = 0; ih; i++) left[i] = arr[i];
for(i = 0; im; i++) right[i] = arr[h+i];

merge_sort(left,h);
merge_sort(right,m);
merge(left,right,h,m,arr);
}

}
void merge(int* left,int* right,int h, int m, int arr[])
{
int i,j,k,t;
i = j =k = 0;
while( ih && jm)
{
if(*(left+i) *(right+j)) arr[k]=left[i++];
else arr[k] = right[j++];
k++;
}

if(ih-1)
{
for( t=k; th+m;t++)
arr[t] = right[j++];
}
else
{
for(t = k; th+m; t++)
arr[t] = left[i++];
}
}

2번방법

void merge_inplace_sort(int unsorteddata[], int low, int high)
{
int mid;
if(highlow)
{
mid = (low + high)/2;
merge_inplace_sort(unsorteddata,low, mid);
merge_inplace_sort(unsorteddata,mid+1, high);
merge_inplace(unsorteddata,low, mid, high);
}
}
void merge_inplace(int unsorteddata[], int low, int mid, int high)
{
int i, j, k,t;

i = low;
j = mid +1;
k = low;
int *temparr;
temparr = (int*)malloc(sizeof(int)*(high+1));

while(i=mid && j=high)
{

if(unsorteddata[i] unsorteddata[j]) temparr[k++] = unsorteddata[i++];

elsetemparr[k++] = unsorteddata[j++];
}
if(imid) for(t=j;t=high;t++) temparr[k++]=unsorteddata[t];
else for(t=i;t=mid;t++) temparr[k++]=unsorteddata[t];
for(t = low; t=high; t++) unsorteddata[t] = temparr[t];

free(temparr);
}

보기에 불편하실수 있을거 같네요.. 차이점 좀 알려주세요~!

신청하기





COMMENT

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

번호 제 목 글쓴이 날짜
2698012 2~9가아닌수 아놀드 2025-06-13
2697980 for에 gets함수를 넣으니까 왜 반복이 안되죠 ㅜ (2) 펴라 2025-06-12
2697952 2차배열과 함수문의^^; VanilLa 2025-06-12
2697924 다차원 배열 질문있습니다 두동 2025-06-12
2697893 정올 :: 기초다지기 a9007 배열7 (문제가 이상함 -_-) 흰두루 2025-06-12
2697862 Unable......... 지정된 파일을 찾을 수 없습니다!! (1) Creator 2025-06-11
2697761 그러니까여제말은... (2) 새론 2025-06-10
2697737 정올 문제좀 풀어보신분~ 레오 2025-06-10
2697709 rand함수 질문좀요! (6) 가막새 2025-06-10
2697683 C언어 변수뒤 표시가 이해안되는게 있습니다. 소미 2025-06-10
2697660 껍데기딜 만들고 난후 어느핫키 누르면 코드검색이라도 뜨고 그다음 무반응 해결좀 (2) 움찬 2025-06-09
2697634 c언어로 감성사전 만들기! (1) 도란도란 2025-06-09
2697605 이 함수좀... agine 2025-06-09
2697574 배열 기본적인질문 (3) 민트향 2025-06-09
2697549 배열 초기화 (4) 나리 2025-06-08
2697465 수다님...^^ (2) 가론 2025-06-08
2697432 서버 만드는 함수에서 궁금한게있어요~ 파랑 2025-06-07
2697401 열혈강의 문제오류 (1) 꿈 2025-06-07
2697374 기초적인 C언어 프로그래밍 입니다. 얼 2025-06-07
2697341 좌우대칭 문제인데 Q가 입력되면 종료가 되야하는데 되지않습니다 무지개 2025-06-07
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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