각종 정렬 방법을 이용해 데이터를 정렬하는 코드에서 문제가 생기네요 ㅠㅠ
카제
질문 제목 : 각종 정렬 방법을 이용해 데이터를 정렬하는 코드에서 문제가 생기네요 ㅠㅠ맨 밑에 빨간 부분 쳐진 곳에서 입력 형식을 어찌 해야 할지 모르겠습니다 ㅠㅠ
텍스트 파일을 입력 받아서 여러 정렬 방법을 이용하여 정렬을 하는 프로그램인데,
함수 구현에서 좀 문제가 생기네요 ㅠㅠ질문 내용 :
#includestdio.h
#includestdlib.h
#includestring.h
#defineswap(x, y, t) ((t) = (x), (x) = (y), (y) = (t))
typedef struct data_size{
int index;
int key;
}dsz;
dsz data[10000];
int count;
void insertion_sort(dsz data[], int count);
void quick_sort(int data[], int left, int right);
void selection_sort(int data[], int count);
int partition(int data[], int left, int right);
void menu();
int main() {
file *fp;
char filename[20];
int i = 0;
printf(enter input file name : );
scanf(%s, filename);//파일이름으로 파일 오픈
getchar();
if((fp = fopen(filename, rt))==null)//파일 이름이 잘못 입력되었을 경우 종료
{
printf(err);
system(pause);
}
for(i = 0 ; i 10000; i++) {
fscanf(fp, %d %d, &data[i].index, &data[i].key);// hw2.data 안에 있는 자료들을 students구조체로 복사.
count++;
if(data[i].key == null)
break;
}
menu();
}
void insertion_sort(dsz data[], int count) {
int i, j;
int compares;
dsz next;
for(i = 1; i count; i++) {
next = data[i];
for(j = i-1; j = 0 && next.key data[i].key; j--)
data[j+1] = data[j];
data[j+1] = next;
compares++;
}
}
void selection_sort(int data[], int count) {
int i, j, least_index, temp;
int k;
int compares;
for (i=0; icount-1; i++){
least_index = i;
// finding the minimum value
for (j=i+1; jcount; j++)
{
if (data[j] data[least_index])
least_index = j;
}
if (i != least_index)
swap(data[i], data[least_index], temp);
compares++;
}
}
void quick_sort(int data[], int left, int right) {
if(left right) {
int q = partition(data, left, right);
quick_sort(data, left, q-1);
quick_sort(data, q+1, right);
}
}
int partition(int data[], int left, int right) {
int pivot, temp;
int low, high;
int compares;
low = left;
high = right +1 ;
pivot = data[left];
do {
do
low++;
while(data[low] pivot);
do
high--;
while(data[high] pivot);
if(low high) swap(data[low], data[high], temp);
compares++;
} while(low high);
swap(data[left], data[high], temp);
return high;
}
void menu() {
int button;
printf(\n******************* m e n u **********************\n);
printf(* 1. sorting by insertion sort *\n);
printf(* 2. sorting by selection sort *\n);
printf(* 3. sorting by quick sort *\n);
printf(* 4. exit program *\n);
printf(****************************************************\n);
fflush(stdin);
printf(choose one what you want to sort : );
scanf(%d, &button);
switch(button){
case 1 : insertion_sort(data, count); break;
case 2 : selection_sort(data[], count); break;
case 3 : quick_sort(data[], 0, count-1); break;
case 4 : exit(-1); break;
default : printf(please select again); menu(); break;
}
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692374 | 고수님들 댓글 마니부탁해요!!! (2) | 엄지 | 2025-04-22 |
2692343 | scnaf에 자꾸 선언을 참조하라는데;; (8) | 도래 | 2025-04-22 |
2692282 | 도스상에서 생성된 exe파일에 press~ 뜨게 하기 (4) | 회사원 | 2025-04-21 |
2692256 | scanf("%*c"); ㅠㅠ 고수님들 | 거북이 | 2025-04-21 |
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 |