수다닷컴

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

기수정렬에 관한 질문입니다.

나샘

2023.04.01

하핫.오랜만이네요.학교 개학하고 나서..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);}

신청하기





COMMENT

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

번호 제 목 글쓴이 날짜
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
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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