버블 정렬 알고리즘 개선 방법
찰스
질문 제목 : 버블 정령 알고리즘 개선 방법버블 정렬의 단점을 개선할 수 있는 코드 수정질문 내용 :데이터(숫자)의 크기를 순차적으로 오름차순으로 정렬하는 버블 정렬 알고리즘을 사용할 때,
처음부터 끝까지 데이터 비교를 하는 버블정렬의 단점을 개선코자, 이미 정렬되있는 상태에서는
비교를 하지 않고 넘어가도록 하는 코드로 수정을 해보았습니다.방법은 기존의 버블 정렬 알고리즘 코드를 if, else를 추가하여, else에 포함시키고 if에는 오름차순이 맞다면 그냥 넘어가도록 하는 코드를 넣고 이를 for문으로 묶었습니다..하지만... 처음부터 끝까지 다 정렬 되어있는 경우만 넘어가고 중간에 정렬이 안되어있다면 그때부터 다시 찾는 방식은 모르겠. ㅠ
수정한 코드가 비효율적인것 같아 자문을 구합니다. ㅠ ㅠ#include stdio.hvoid bubblesort(int dataset[], int length)
{
int i = 0;
int j = 0;
int temp = 0;
int k = 0;
//이 부분부터
for (k=0; klength-1; k++){
if(dataset[k+1]dataset[k]){
}
else{
//이 부분까지가 코드개선을 위해 수정작업한 코드입니다.
for (i=0; ilength-1; i++) {
for (j=0; jlength-(i+1); j++) {
if (dataset[j] dataset[j+1]) {
temp = dataset[j+1];
dataset[j+1] = dataset[j];
dataset[j] = temp;
}
}
}/bsp; }
}
}
}int main(int argc, const char * argv[])
{ // insert code here... int dataset[] = {1,2,3,4,5};
int length = sizeof dataset / sizeof dataset[0];
int i = 0;
bubblesort(dataset, length);
for (i=0; ilength; i++) {
printf(%d\n, dataset[i]);
}
printf(\n);
return 0;
}고수님의 효율적인 방법이 궁금합니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692230 | 하노이탑 질문입니다. (1) | 미쁘다 | 2025-04-21 |
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |
2691510 | sizeof 연산자 질문입니다 (2) | 종달 | 2025-04-14 |