합병정렬 시간 차이 문의 입니다.
물고기자리
질문 제목 :
합병 정렬 소스 문제점좀 알려주세요..(첨부)질문 내용 :
합병정렬을 코딩 하는 중인데요.
동적할당으로 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);
}
보기에 불편하실수 있을거 같네요.. 차이점 좀 알려주세요~!
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |