기수정렬에 관한 질문입니다.
나샘
하핫.오랜만이네요.학교 개학하고 나서..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);}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2699161 | for loop안에 있는 if문 (9) | Orange | 2025-06-23 |
2699105 | 링크더리스트 이전 링크값 출력함수. | 꼬꼬마 | 2025-06-23 |
2699078 | 정수를 한자리씩 배열에 담는 법은 어떻게 하나요.. (4) | 귀염포텐 | 2025-06-22 |
2699024 | C언어 공부하려는데 도와주세요!!! (2) | 달님 | 2025-06-22 |
2698994 | 날짜 계산하는 C 코드 짜고 있는데 꽉 막혀서 질문드립니다.. (6) | 별 | 2025-06-22 |
2698967 | 파일삭제 윈도우 폴더까지 접근하게하는 함수가 뭔가요 (2) | 샤인 | 2025-06-21 |
2698938 | c언어 메모리질문 (3) | 나래 | 2025-06-21 |
2698909 | 서비스 요청 고객 관리 프로그램 짜는것좀 도와주세요ㅜㅜ (4) | 궁수자리 | 2025-06-21 |
2698882 | 프로그래밍좀 짜주세요 (3) | 황예 | 2025-06-21 |
2698855 | 카프-라빈 알고리즘 코딩 분석좀 도와주세요.. | 꽃봄 | 2025-06-20 |
2698829 | 학점계산기 (7) | MyWay | 2025-06-20 |
2698782 | 기초적인 함수 질문이요ㅠㅠㅠㅠ | 내담 | 2025-06-20 |
2698749 | 프로그램 짜던 도중 패닉입니다...ㅜ | 파랑 | 2025-06-19 |
2698719 | 조건부컴파일 질문입니다.~ (2) | 큐트 | 2025-06-19 |