버블정렬 알고리즘의 성능 개선 관련 질문입니다
한빛
질문 제목 : 버블정렬 알고르즘의 성능 개선(한 단계에서 더이상 교환이 없으면 이미 정렬된 것이므로 알고리즘을 종료)
버블정렬 알고리즘은 주어졌는데 어떻게 수정해야지 개선되고 또 몇번째 데이터에서 종료된건지 출력해야되는데
책 이것저젓 찾아봐도 어떻게 할찌 잘모르겟네여
질문 내용 : 이알고리즘을 개선해야 됩니다
#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문 종료해 버리고 종료된 시점을 리턴하면 될듯도 합니다만은... 음 -_-;
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2690517 | cygwin에서요.. (1) | 엘보어 | 2025-04-05 |
2690486 | 문자열과 문자형이요 ~ | 다스리 | 2025-04-05 |
2690344 | 일본어 주석 깨짐 문제 (3) | 연하얀 | 2025-04-04 |
2690314 | 암호문 만들기 -비제네르- | 이퓨리한나 | 2025-04-03 |
2690292 | 왕초보자의 질문!!!!!! 도와주세요 (1) | 하랑 | 2025-04-03 |
2690269 | 정올 문제 인데.. 흠 | 반월 | 2025-04-03 |
2690237 | sizeof에서 short형을 썻는데 왜 4byte가 나올까요? (1) | 바나나 | 2025-04-03 |
2690183 | 문자열과 포인트 비교 (2) | 미즈 | 2025-04-02 |
2690154 | a -48 ? | 희미한눈물 | 2025-04-02 |
2690094 | 테트리스 질문요. | 지후 | 2025-04-01 |
2690066 | 문자열비교!! (1) | 매디 | 2025-04-01 |
2689888 | 좀도와주세요;; ㅠㅠ | 사람 | 2025-03-30 |
2689856 | 메뉴 그리는 거 질문 | 나라빛 | 2025-03-30 |
2689831 | c언어 프로그램 추천 | 하연 | 2025-03-30 |
2689801 | c언어 time.h에서 작동이 중지되었습니다. | 하람 | 2025-03-30 |
2689772 | 2차원 배열의 배열명에 대해서.. | 옆집꼬마야 | 2025-03-29 |
2689740 | 게임 TCP소켓 질문 (2) | 불꾼 | 2025-03-29 |
2689711 | 반복문 모래시계 | 한뎃집 | 2025-03-29 |
2689685 | 경우의 수에 따른 결과 처리 질문드립니다. (2) | 다흰 | 2025-03-29 |
2689655 | .exe에 아이콘 넣는 법좀 알려주세요 | 연하얀 | 2025-03-28 |