이해를 할수없습니다.
푸른나래
이해를 할수가없어요,.이제 막 c언어 배우기 시작한 단계인데요 학교에서 배웠는데 하나도 모르겠습니다 설명좀 가능할지 부탁드립니다.
실행 시키면 배열이 나오는것 같은대..왜 설명좀 부탁드리겠습니다.
질문 내용 : #include stdio.h
#include stdlib.h
#define maxlen 100
#define maxrow 100
#define maxcol 100
#define maxpage 100
int *createltemsd(int *, int);
int numgen();
void accessltemsd(int [], int);
void sortltemsd(int [],int);
void swap(int *, int *);
int searchltemd(int [], int, int);
int insertltemd(int [], int, int);
int deleteltemd(int [], int, int);
main() {
int a[maxlen];
int *ptr = a;
int item, pos, len = 10;
// 배열 항목 생성 함수
printf(\n[배열 항목 생성 함수]\n);
ptr = createltemsd(ptr, len);
// 배열 항목 출력 함수
accessltemsd(a, len);
//배열 항목 정렬 함수
printf(\n[배열 항목 정렬 함수\n);
sortltemsd(a, len);
accessltemsd(a, len);
// 배열 항목 탐색 함수
printf(\n[배열 항목 탐색 함수\n);
item = 59;
pos = searchltemd(a, len, item);
if (pos == -1)
printf(%d : 찾는 항목이 없습니다.\n, item);
else
printf(%d : %d번째 항목 입니다.\n, item, pos);
accessltemsd(a, len);
// 배열 항목 삽입 함수
printf(\n[배열 항목 삽입 함수]\n);
item = 39;
printf(%d : 항목 삽입 값\n, item);
len = insertltemd(ptr, len, item);
accessltemsd(a, len);
//배열 항목 삭제 함수
printf(\[배열 항목 삭제 함수]\n);
item = 39;
printf(%d : 항목 삭제 값\n, item);
len = deleteltemd(a, len, item);
accessltemsd(a, len);
}
/* 주어진 길이만큼 배열 항목을 생성 함수 */
int *createltemsd(int a[], int len) {
int i;
//전체 배열 초기화
for(i=0; imaxlen; i++)
a[i] = -9999;
//길이만큼의 배열 항목 생성
// numgen() : 랜덤 수 1 ~ 32767 사이의 값 생성 함수
for(i=0; ilen; i++)
a[i] = numgen();
return a;
}
/* 1 ~ 100 사이 값을 생성하는 랜덤 함수 */
int numgen() {
return rand() % 100 + 1;
}
/* 배열의 모든 항목 출력 함수 */
void accessltemsd(int a[], int len) {
int i;
for(i=0; ilen; i++)
printf(a[%d] = %d\n, i, a[i]);
}
/* 오름차순 선택정렬 (increasing order selection sort) */
void sortltemsd(int a[], int len) {
int i,j, minpos;
for (i=0; ilen-1; i++) {
minpos = i;
for(j=i+1; jlen; j++)
if (a[minpos] a[j])
minpos = j;
swap(&a[minpos], &a[i]);
}
}
/* 두 값을 교환하는 함수 */
void swap(int *x, int *y) {
int temp;
temp = *x;
*x = *y;
*y = temp;
}
/* 순차탐색(sequential search) : 배열 항목 탐색 함수 */
int searchltemd(int a[], int len, int item) {
int i = 0;
while (i len) {
if (a[i] == item)
return i; // i 번째 항목에서 찾음
i++;
}
return -1;// 찾는 항목 없음
}
/* 오름차순으로 정렬된 배열에서 특정 항목 삽입 함수 */
int insertltemd(int a[], int len, int item) {
int i = 0, pos = 0;
//오우버플로우 체크
if (len = maxlen || len 0)
return -1;
//배열의 크기가 0인 경우
else if (len ==0) {
a[len] = item;
return ++len;
}
//삽입 위치 : 항목 중 첫 번째로 item 보다 큰 수의 자리
while (i len) {
if (a[i] item) {
pos = i;
break;
}
i++;
}
//삽입 위치가 마지막 항목일 경우
if (pos == len)
a[len] = item;
//삽입 위치가 마지막 항목이 아닐 경우 : 이동 후 삽입
else {
for (i=len; ipos; i--)
a[i] = a[i-1];
a[pos] = item;
}
return ++len;// 배열의 길이는 1증가
}
/* 오름차순으로 정렬된 배열에서 특정 항목 삭제 함수 */
int deleteltemd(int a[], int len, int item) {
int i = 0, pos;
// 언더플로우 체크
if (len = 0 || len = maxlen)
return -1;
// 항목 삭제 위치를 찾음
pos = searchltemd(a, len, item);
// 항목을 찾지 못했을 경우
if (pos == -1)
return -1;
// 항목을 찾았을 경우 삭제 위치로 나머지 항목 이동
for (i=pos; ilen-1; i++)
a[i] = a[i+1];
return --len;// 배열의 길이는 1 감소
}