버블정렬 알고리즘의 성능 개선 관련 질문입니다
한빛
질문 제목 : 버블정렬 알고르즘의 성능 개선(한 단계에서 더이상 교환이 없으면 이미 정렬된 것이므로 알고리즘을 종료)
버블정렬 알고리즘은 주어졌는데 어떻게 수정해야지 개선되고 또 몇번째 데이터에서 종료된건지 출력해야되는데
책 이것저젓 찾아봐도 어떻게 할찌 잘모르겟네여
질문 내용 : 이알고리즘을 개선해야 됩니다
#include stdio.h
#include stdlib.h
#include time.h
#define n 10000
#define true 1
#define false 0
void swap(int a[], int i, int j)
{
int t = a[i];
a[i] = a[j];
a[j] = t;
}
void checksort(int a[], int n)
{
int i, sorted;
sorted = true;
for (i=1; in; i++) {
if (a[i] a[i+1]) sorted = false;
if (!sorted) break;
}
if (sorted) printf (정렬 완료!\n);
else printf (정렬오류 발생!\n);
}void bubblesort(int a[], int n)
{
int i, j;
for(i=n; i=1; i--) {
for(j=1; ji; j++)
if (a[j] a[j+1])swap(a, j, j+1);
}
}main()
{
int i, a[n+1];
double start_time;
// 버블정렬 테스트
srand(time(null));
for (i=1; i= n; i++) a[i] = rand();
start_time = clock();
bubblesort(a, n);
printf (버블정렬의 실행시간(n=%d) : %f\n, n, (clock() - start_time)/clocks_per_sec);
checksort(a, n);}
-
쇼코홀릭 2024-07-27
BubbleSort() 안에 플래그 하나 두고 스왑하는지 않아는지만 체크 하면 될것 같네요
스왑하지 않으면 for문 종료해 버리고 종료된 시점을 리턴하면 될듯도 합니다만은... 음 -_-;
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2694069 | unsigned 질문입니다. | 힘차 | 2025-05-07 |
2694012 | 전공 비전공자 개발자 (10) | 말글 | 2025-05-07 |
2693984 | 오버로딩이 무엇인가요? (2) | 헛매질 | 2025-05-07 |
2693956 | PlaySound재생이 안됩니다!(C에 음악넣기) | 지존 | 2025-05-06 |
2693928 | &와 *의 사용에 관한 명확한 이해 | 제나 | 2025-05-06 |
2693903 | 반복문 설명좀요 ㅠㅠ (2) | 란새 | 2025-05-06 |
2693869 | stdio.h 는 왜 쓰는건가요? (1) | 큰꽃들 | 2025-05-06 |
2693842 | 포인터 변수의 주소값끼리 더하는 것에 대해서 질문드립니다. (1) | 진솔 | 2025-05-05 |
2693811 | 소수 출력;;;; | 화이트캣 | 2025-05-05 |
2693788 | 이런 함수는 없나요? (3) | 앤드류 | 2025-05-05 |
2693758 | txt파일 불러와서 행렬로 저장 | 큰애 | 2025-05-05 |
2693727 | scanf 오류 문제!! (2) | 큰나래 | 2025-05-04 |
2693704 | 구조체 주소록 문제인데 도와주세요 (2) | 도1도캣 | 2025-05-04 |
2693676 | 열혈강의 c언어 질문입니다 | 하양이 | 2025-05-04 |
2693647 | 12.620000 을요 12.620 으로 어떻게 표현해요? (2) | 파도 | 2025-05-04 |
2693619 | 타이틀 코드.. | 단순드립 | 2025-05-03 |
2693591 | 컴파일 에러에서 질문드립니다 (3) | 게자리 | 2025-05-03 |
2693463 | 동적할당 이용시 fwrite사용을 어떻게 해야하나요..? (10) | 일본어못해요 | 2025-05-02 |
2693387 | 배열문제입니다 수정오류캡쳐했습니다 (6) | 연하얀 | 2025-05-01 |
2693356 | text 입출력 내림차순 질문입니다 ㅠ | 빛글 | 2025-05-01 |