파일 입출력을 통한 정렬 프로그램 질문입니다.
가을바람
파일 입출력을 통한 정렬 프로그램입니다.질문 요약 :파일에 있는 데이터를 배열에 삽입하는 것에 대한 질문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파일을 첨부하겠습니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2694420 | C언어 질문할게요(유니코드,자료형,버퍼,캐스트연산자) | 은새 | 2025-05-11 |
2694370 | 내일까진데 함수호출 제발 도와주세요!!!!!!!!!11 | 들찬 | 2025-05-10 |
2694339 | putchar()의 괄호 안에 int c=10;로 전에 선언된 c를 넣으면 안되는 이유에서 제가 생각한 것이 그 이유가 되는지 확인하고 싶습니다. (3) | 미르 | 2025-05-10 |
2694316 | 이 코드 어디가 잘못되었는지 고수분들 ㅠㅠ (2) | 나빛 | 2025-05-10 |
2694285 | 언어 공부하는 과정 좀 추천해주세요! (1) | 아빠몬 | 2025-05-09 |
2694258 | 카운터.. 질문입니다. (4) | 하늘빛눈망울 | 2025-05-09 |
2694229 | 단순한 질문이요 (8) | 여름 | 2025-05-09 |
2694202 | 용돈을 가지고 할 수 있는 일을 여러가지로 출력하는 방법 좀 알려주세요! (2) | 미나 | 2025-05-09 |
2694145 | 화면깜빡임을 없애고 싶은데요... (1) | 어서와 | 2025-05-08 |
2694069 | unsigned 질문입니다. | 힘차 | 2025-05-07 |
2694012 | 전공 비전공자 개발자 (10) | 말글 | 2025-05-07 |
2693984 | 오버로딩이 무엇인가요? (2) | 헛매질 | 2025-05-07 |
2693956 | PlaySound재생이 안됩니다!(C에 음악넣기) | 지존 | 2025-05-06 |
2693928 | &와 *의 사용에 관한 명확한 이해 | 제나 | 2025-05-06 |
2693903 | 반복문 설명좀요 ㅠㅠ (2) | 란새 | 2025-05-06 |
2693869 | stdio.h 는 왜 쓰는건가요? (1) | 큰꽃들 | 2025-05-06 |
2693842 | 포인터 변수의 주소값끼리 더하는 것에 대해서 질문드립니다. (1) | 진솔 | 2025-05-05 |
2693811 | 소수 출력;;;; | 화이트캣 | 2025-05-05 |
2693788 | 이런 함수는 없나요? (3) | 앤드류 | 2025-05-05 |
2693758 | txt파일 불러와서 행렬로 저장 | 큰애 | 2025-05-05 |