기수정렬에 관한 질문입니다.
헛장사
하핫.오랜만이네요.학교 개학하고 나서..C공부가 게을러져서 걱정이랍니다.다름이 아니고 제가 알고리즘을 공부하는데 기수정렬을 한번 짜볼랬는데,개념이 아직 덜서서 그런지 만만치않더라구요.그래서 인터넷을 뒤지다 소스를 하나 발견해서 제가 이리저리 손을 좀봐가지고 되게는 만들었는데 이해가 안되는 부분이 있어서그부분은 빨간색으로 표시하였습니다.제개인적인생각으론 큐를 C로구현함에 있어 개념이 없는거 같기도 합니다..C자체가.. 개념이 없어서인거 같기도 하구요..많은 조언과 가르침 부탁드립니다.#includestdio.h
#includestdlib.hvoid radix_sort(int arr[], int n)//n만큼의 데이터가 들어있는 arr배열을 기수정렬
{
int i, j, k, a, r;
int *que[10], top[10];for(i=0; i10; i++)//사용할 큐를 초기화
{
que[i] = (int *)malloc(sizeof(int)*n);
top[i] = -1;
}
j=arr[0];
for(i=1;in;i++)//최대값을 찾아서 몇자리의 수인지 확인
{
if(arr[i]j)
j=arr[i];
}r=1;//최대값과 기수 비교(자리수)
do
{
r*=10;
}while(r=j);for(i=1; i=r; i*=10)//정렬할 자릿수
{
for(j=0 ; jn; j++)//해당 자릿수의 큐에 데이터저장
{
k=(arr[j]/i)%(10);
que[k][++top[k]]=arr[j];
}a=0;//자릿수 순서대로 큐의 데이터를 꺼냄
for(j=0; j10; j++)
{
for(k=0; k=top[j]; k++)
{
arr[a++]=que[j][k];
}
top[j]=-1;
}
}for(i=0; i10; i++)
{
free(que[i]);
}
}
int main (void)
{
int array[5];
int in,i; printf(배열입력을 시작합니다.(5개의 숫자 입력)\n);
for(i=0;i5;i++){
printf(숫자를 입력하시오 : );
scanf(%d,&in);
array[i]=in;
}
printf(정렬전 완성된 배열은 );
for(i=0;i5;i++){
printf(%d ,array[i]);}
printf(입니다\n);radix_sort(array,5);printf(정렬후 완성된 배열은 );
for(i=0;i5;i++){
printf(%d ,array[i]);}
printf(입니다\n);}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676182 | 숫자 순서대로 배열하는법 | 권뉴 | 2024-11-24 |
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |