버블 정렬 알고리즘 개선 방법
찰스
질문 제목 : 버블 정령 알고리즘 개선 방법버블 정렬의 단점을 개선할 수 있는 코드 수정질문 내용 :데이터(숫자)의 크기를 순차적으로 오름차순으로 정렬하는 버블 정렬 알고리즘을 사용할 때,
처음부터 끝까지 데이터 비교를 하는 버블정렬의 단점을 개선코자, 이미 정렬되있는 상태에서는
비교를 하지 않고 넘어가도록 하는 코드로 수정을 해보았습니다.방법은 기존의 버블 정렬 알고리즘 코드를 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;
}고수님의 효율적인 방법이 궁금합니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2700668 | c언어 질문입니다. 도와주세요~ (3) | 가자 | 2025-07-07 |
2700639 | 한글입력받아서 ㄱㄴㄷ순서대로출력하는법좀 | 두빛나래 | 2025-07-06 |
2700610 | 정말 기초적인 더하기,여백 문제 help | 무슬 | 2025-07-06 |
2700562 | 함수포인터에서요 (7) | 소심한여자 | 2025-07-06 |
2700530 | 전처리문 질문입니다. (1) | 아놀드 | 2025-07-05 |
2700510 | c언어를 어케하면 잘할수 있을까요.. | 연연두 | 2025-07-05 |
2700484 | 두 개가 차이가 뭔지 알려주세요...(소수 찾는 프로그램) (2) | 날위해 | 2025-07-05 |
2700426 | 인터넷 창 띄우는 질문이요 (1) | 정훈 | 2025-07-04 |
2700400 | 원넓이를 계산이요 ㅜㅜ | 천칭자리 | 2025-07-04 |
2700368 | if에 관해서 질문이요... | Orange | 2025-07-04 |
2700339 | 이거 결과값이 왜이런건지.. (4) | 그댸와나 | 2025-07-04 |
2700313 | 파일 읽어서 저장하는데 빈파일일 경우 문재가 발생하네요.. (2) | 크나 | 2025-07-03 |
2700287 | 구조체 동적할당 연습을 하는데 오류가 뜹니다...(해결) (3) | 아련나래 | 2025-07-03 |
2700264 | 문자와 숫자 동시에 입력??? | 글고운 | 2025-07-03 |
2700236 | txt파일로만 쓰고 읽게 하려면 어떻게 해야 하나요..?? (8) | 미국녀 | 2025-07-03 |
2700211 | 전위 연산자 (2) | 어른처럼 | 2025-07-02 |
2700183 | C에서 파일이름을 받고, 그 파일의 사이즈를 출력해줘야하는데 내용이 출력이 안되네요 ;ㅅ; | 피스케스 | 2025-07-02 |
2700150 | 꼭좀 도와주세요ㅠㅠㅠ | 호습다 | 2025-07-02 |
2700095 | 연산문제...질문... | 오빤테앵겨 | 2025-07-01 |
2700070 | while문 , 3의배수 출력하는 프로그램좀 짜주세욤. | 횃불 | 2025-07-01 |