파일 입출력을 통한 정렬 프로그램 질문입니다.
가을바람
파일 입출력을 통한 정렬 프로그램입니다.질문 요약 :파일에 있는 데이터를 배열에 삽입하는 것에 대한 질문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파일을 첨부하겠습니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2697374 | 기초적인 C언어 프로그래밍 입니다. | 얼 | 2025-06-07 |
2697341 | 좌우대칭 문제인데 Q가 입력되면 종료가 되야하는데 되지않습니다 | 무지개 | 2025-06-07 |
2697314 | fprintf와 fscanf 로 파일 입출력 할떄 | 밝음이 | 2025-06-06 |
2697293 | 툴 소스 뽑아내는법 | 도움 | 2025-06-06 |
2697264 | 소소한거 두어가지 질문할께요~ (8) | 별솔 | 2025-06-06 |
2697235 | scanf로 인풋 받을 때?! | 보담 | 2025-06-06 |
2697207 | 열혈강의 연습문제 질문이요~ (2) | 맥적다 | 2025-06-05 |
2697182 | strcmp, strtok - 어떤 기능을 하는지... | 루다 | 2025-06-05 |
2697129 | [질문] 아래 저축액을 계산하는 프로그램 ㅠ 추가 질문 (7) | 찬늘 | 2025-06-05 |
2697072 | 쌩초보 질문! (1) | 얀 | 2025-06-04 |
2697050 | 도움부탁드립니다.. | 화이트 | 2025-06-04 |
2697023 | gotoxy함수, 어떻게 사용하죠? (3) | 적송 | 2025-06-04 |
2696994 | c언어를 막 시작한 초보인데 질문이 있어용 ㅠㅠ (2) | 귀1여운렩 | 2025-06-03 |
2696944 | 윈도우 콘솔프로그램 질문드립니다 (2) | 꽃님이 | 2025-06-03 |
2696882 | c언어 입력받기 질문 입니다 (2) | 흰추위 | 2025-06-02 |
2696853 | 문자열은 정적메모리에 할당된다고 하는데 정적메모리가 뭡니까?? (6) | 다온 | 2025-06-02 |
2696799 | c c++언어입문전에 파이톤이나 자바스크립트배워두면.. (2) | 앨런 | 2025-06-02 |
2696747 | size of 연산자에 대해 질문이 있습니다. (3) | 유진공주 | 2025-06-01 |
2696721 | Char 타입의 2D array 기초에 대해 질문드립니다. | 벚꽃 | 2025-06-01 |
2696691 | 자릿수 이동방법좀 가르쳐주세요 (1) | 흰추위 | 2025-06-01 |