파일 입출력을 통한 정렬 프로그램 질문입니다.
가을바람
파일 입출력을 통한 정렬 프로그램입니다.질문 요약 :파일에 있는 데이터를 배열에 삽입하는 것에 대한 질문1과 기타 질문1이 있습니다.질문 내용 :
소스파일과같은 폴더에 있는
파일(.txt)을 프로그램 상으로
불러들여 선택 정렬, 삽입 정렬, 버블정렬 중
선택을 하여 출력하는 프로그램입니다.
한번 실행을 해보시면 어떤 프로그램인지 간단하게 아실수 있을거라 생각합니다.
일단 소스 공개합니다.
#include stdio.h/*---------------------------global variables----------------------------------*/
file *fp;
char filename[20];
int size;/*---------------------------function prototypes-------------------------------*/
void insertion_sort(int data[], int n);
void bubble_sort(int data[], int n);
void select_sort(int data[], int n);/*******************************************************************************
* *
* main program *
* sp; *
*******************************************************************************/
int main(void)
{
int i, num;
int data[8];
while(1) //무한반복
{
printf(************************************************************************);
printf(\n*\t\t\tword sort program\t\t\t *\n);
printf(*\t\t\t=================\t\t\t *\n);
printf(* description : 이 프로그램은 sort.c 파일과 같은 폴더에 있는 *\n);
printf(* txt 파일(정수들이 적혀있는 파일)을 프로그램 상으로 *\n);
printf(* 불러들여 선택 정렬, 삽입 정렬, 버블정렬 중 *\n);
printf(* 선택을 하여 출력하는 프로그램입니다. *\n);
printf(************************************************************************\n); system(pause);
printf(\n\t불러들일 파일명을 입력하세요(예: *.txt) : ); //파일명을 입력받아 문구 출력
scanf(%s,filename); //입력받은 문자열을 filename에 저장
printf(\n);
fp=fopen(filename,r); //파일을 읽기전용으로 염
if(fp==null){//열린 파일이 없으면
printf(해당 파일이 없습니다.\n); //에러문구 출력하고 다시 반복
return;
}
else{ //아니면
printf(파일을 읽었습니다.\n);
break; //무한반복 탈출
}
return; //존재하지 않는 파일을 입력할 경우, 다른 메뉴를 이용하기 위해 메뉴로 이동하기 위한 리턴문
}
for(i=0; i8; i++)
fscanf(fp,%d, &data[i]);
size=i;
while(1){
printf(************************************************************************\n);
printf(* 메 뉴 *\n);
printf(* *\n);
printf(* 1. 선택정렬 2.삽입입력 *\n);
printf(* 3. 버블정렬 4.종료 *\n);
printf(* *\n);
printf(************************************************************************\n);
printf(\n메뉴를 선택하세요 : );
scanf(%d, &num);
if(num == 4) return 0; //int 형 메인 함수이므로 종료 시에 return 문을 사용
switch(num) {
case 1:
select_sort(data, size);
printf(선택정렬을 선택하셨습니다.);
break;
case 2:
insertion_sort(data, size);
printf(삽입정렬을 선택하셨습니다.);
break;
case 3:
bubble_sort(data, size);
printf(버블정렬을 선택하셨습니다.);
break;
default:
printf(잘못 선택하셨습니다.\n);
}
system(pause);
system (cls);
} return 0;
}
/*******************************************************************************
* function insertion_sort() : 삽입 정렬을 하여 출력하는 함수 *
* *
*******************************************************************************/
void insertion_sort(int data[], int n)
{
int i, j, t, temp;
printf(\n 정렬할 원소 : );
for(t=0;tsize;t++) printf( %d , data[t]);
printf(\n\n삽입정렬 수행\n);
for(i=1; isize;i++){
temp=data[i];
j=i;
while((j0) && (data[j-1]temp)){
data[j]=data[j-1];
j=j-1;
}
data[j]=temp;
printf(\n %d 단계 : , i);
for(t=0; tsize; t++) printf(%7d, data[t]);
}
printf(\n);
}/*******************************************************************************
* function insertion_sort() : 선택 정렬을 하여 출력하는 함수 *
* *
*******************************************************************************/
void select_sort(int data[], int n)
{
int i, j, t, min, temp;
printf(\n 정렬할 원소 : );
for(t=0;tsize;t++) printf( %d , data[t]);
printf(\n\n선택정렬 수행\n);
for(i=0; isize-1;i++){
min=i;
for(j=i+1;jsize;j++){
if(data[j]data[min]) min=j;
}
temp = data[i];
data[i] =data[min];
data[min] = temp;
printf(\n%d단계 : , i+1);
for(t=0; tsize; t++) printf(%7d, data[t]);
}
printf(\n);
}/*******************************************************************************
* function insertion_sort() : 정렬을 하여 출력하는 함수 *nbsp; *
* *
*******************************************************************************/
void bubble_sort(int data[], int n)
{
int i, j, t, temp;
printf(\n 정렬할 원소 : );
for(t=0;tsize;t++) printf(%d, data[t]);
printf(\n\n버블정렬 수행\n);
for (i=size-1; i0; i--){
printf(\n %d 단계, size-i);
for(j=0;j=i; j++){
if (data[j-1]data[j]){
temp = data[j-1];
data[j-1] = data[j];
data[j] = temp;
}
printf(\n\t);
for(t=0; tsize; t++) printf(%7d, data[t]);
}
printf(\n);
}
}
질문 1입니다.
txt파일에 있는 데이터(정수)들을 배열에 삽입해야하는데요
제가 현재 한 코딩은 데이터가 딱 8개여야 합니다.(파란 글씨로표시된 곳.)
데이터를 불러들일때 고정된 8개가 아닌 txt 파일에 저장된 갯수만큼 배열에 삽일할 수 있는 방법은 무엇입니까?
예) txt 파일에 50개 이하로 데이터가 저장되어 있으면 그 갯수만큼 배열로 불러들이는 방법.
기타 질문 입니다.
메뉴에서 정렬을 선택하고 나면 배열이 정렬된 상태가 되잖아요. 그 상태에서 다른 정렬 메뉴를 선택해봐야 정렬된 상태라서 정렬이라는 것이 소용이 없을거 같은데요. 한번 정렬 메뉴를 선택하고 다시 배열을 초기화 즉, txt에 있는 파일을 처음 배열로 불러들였을 상태로 되돌릴려면 어떤 방법을 쓰는것이 나을까요?
p.s. txt파일을 불러들이는 함수를 따로 만들려고 하는데요 그럼 배열을 전역변수로 선언해줘야 하나요?
제가 저번에 질문을 올렸었는데요 수다님이 덧글을 남겨주셨는데 이해가 가지 않아 다시 질문을 드립니다.
정말 저의 실력이 모자라 이렇게 죄송한 질문을 다시 드리게 되었습니다.
어떻게 수정해야 할지 간단하게 보여주시기를 부탁드립니다...ㅠ
좋은 정보를 부탁드리겠습니다.^^
txt파일을 첨부하겠습니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676182 | 숫자 순서대로 배열하는법 | 권뉴 | 2024-11-24 |
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |