sizeof를 사용한 것과 사용하지 않는 것의 차이가 궁금합니다(관련질문 有)
그녀는귀여웠다
질문 제목 : sizeof 의 사용한 것과 안한 것의 차이질문 내용 :
열혈강의 연습문제 17-1의 문제입니다
2개의 int형 포인터와 길이가 5인 int형 배열을 선언한 다음 총 5개의 정수를 사용자로 부터 입력받는다.
그리고 나서 두 개의 포인터와 배열을 함수 maxmin의 인자로 전달한다.
함수 호출이 완료되고 나면 max와 min은 배열의 최대값과 최소값을 가리키고 있어야 한다.
이러한 기능을 지니는 함수 maxmin을 정의하고, 이에 적절한 main함수도 구현해 보자.
main 함수의 마지막에서는 포인터 max와 min이 가리키는 메모리가 지니고 있는 값을 출력하기로 하자.
===============================================
연습문제의 답을 보지 않고 코딩을 했습니다.
// exercise 17-1.cpp
#includestdio.h
#pragma warning(disable:4996)
void maxmin(int input,int *num,int **max,int **min);
int main()
{
int num[5]={0, };
int input=0;
int *max,*min;
max=num,min=num;// max, min 포인터가 배열을 가리키게...
while(input5)
{
printf(숫자를 입력해주세요 : );
scanf(%d,&num[input]);
input++;
}
maxmin(input,num,&max,&min);
printf(최대값 : %d \n,*max);
printf(최소값 : %d \n,*min);
return 0;
}
void maxmin(int input,int *num,int **max,int **min)
{
int temp;// 임시저장
int first=0;// 기준이 될 자리
int second=1;// 유동적으로 움직일 자리
// 내림차순 후 max,min(최대값,최소값 구하기)
while(firstinput-1)
{
while(secondinput)
{
if(num[first]num[second])
{
temp=num[first];
num[first]=num[second];
num[second]=temp;
second++;
}
second++;
}
first++;
second=first+1;
}
*max=&num[first];
*min=num;
}
=================================================
연습문제 답입니다.
// exercise 17-1ok.cpp
#includestdio.h
#pragma warning(disable:4996)
void maxmin(int *arr, int size, int **mx, int **mn);
int main()
{
int arr[5];
int *man, *min;
int i;
for(i=0;i5;i++)
{
printf(정수 입력: );
scanf(%d,&arr[i]);
}
maxmin(arr,sizeof(arr)/sizeof(int),&man,&min);
printf(최대 : %d, 최소 : %d \n,*man,*min);
return 0;
}
void maxmin(int *arr, int size, int **mx, int **mn)
{
int i;
int *max, *min;
max=min=arr;
for(i=0;isize;i++)
{
if(*maxarr[i])
{
max=&arr[i];
}
if(*minarr[i])
{
min=&arr[i];
}
}
*mx=max;
*mn=min;
}
빨간색으로 표시한 부분을 보면
2군데 정도 비교를 하고자 표시를 했는데요
1. max, min 포인터의 대입
제가 짠 코드에서는 문제의 이해를 잘못해서 먼저 대입을 했는데...
문제답에서는 maxmin 함수안에서 대입을 했더라구요.
그런데max=min=arr;처럼 대입을 할 경우면 max와 min이 가리키고 있는 것은
arr의 첫번째 주소인건가요? 조금 헷갈리네요
2. sizeof를 사용한 것과 안한 것의 차이
제가 짠 코드에서는 input변수를 그대로 복사를 해서 사용하고
문제에서는 sizeof를 사용해서 배열의 크기를 넘겨줬습니다.
배열을 넘겨줄 때는 꼭 배열의 크기를 넘기는 방식외에도 제가 했던 방식으로 하면
뭔가 프로그램에 문제가 생기는 걸가요?
혹시나 최소값, 최대값이 이상하게 나오는 현상도 있고 해서
배열의 첫번째부터 마지막까지 값을 출력하게 나왔더니 이상하게 나오기는 하더라구요.
그래서 배열의 크기를 구할 수 있는 sizeof 연산자를 쓴것가 싶기도 하구요..
그래서 그 부분이 궁금했습니다. 배열을 함수로 넘길때
배열의 크기를 넘기는 sizeof 연산자 외에 제가 한 방법은 뭔가 비효율적인 것인가 해서요...
글 보시고 답변 부탁드립니다...
-
튼튼
좋은 코드란 잠재된 버그를 숨기는게 아니라
잠재된 버그를 들춰주어 수정할 수 있게 해주는 코드라 생각합니다.
이 점에서는 Rhytem님과 의견울 달리합니더. -
별하
좋은 의견 주셔서 감사합니다
그리고 말씀해주신 코딩에서 3 2 1 3 5 입력해보고 그렇게 나오는 부분에서
제가 같은 수를 넣었을 경우를 생각하지 않았기에 수정했습니다^^
그리고 그와 더불어 sizeof와 제가 변수로 사용한 input을 사용했을 때의 경우...
차이점을 조금 알게 되었습니다.
조금 더 연습을 해봐야되겠군요... 감사합니다^^ -
들빛
결론부터
님이 짜신 코드에는 오류가 있습니다
3 2 1 3 5룰 입력해보세요.
디버깅은 쉬워요.
second++가 2번 되서 아마
min이 2가 될겁니다.
sizeof보다는 님이 하신 방법이 더 확장성이 넓습니다. 배열의 원소 갯수와 사용자로부터 입력받는 정수의 갯수가 같으명 상관이 없으나, 언제나 그러리란 보장은 없잖아요. 님의 방법은 사용자로부터 입력된 숫자의 갯수를, sizeof 방법은 사용자가 입력한 숫자의 갯수와는 관계없이 배열의 원소 갯
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2695166 | do while 문 어떤것이잘못된건지 모르겠어요 (2) | 아이폰 | 2025-05-18 |
2695122 | 구조체에 대해 물어보고 싶은게 있습니다 ^^^.. (7) | 수련 | 2025-05-17 |
2695091 | txt 파일 입출력 후 2차 배열에 저장하기입니다. (3) | 헛장사 | 2025-05-17 |
2695063 | 수도요금 프로그램좀 짜주세요. | 시내 | 2025-05-17 |
2695033 | 답변좀요ㅠㅠ (1) | 비사벌 | 2025-05-16 |
2695010 | C++의 STL은 왜 굳이 템플릿화 시켜서 라이브러리를 만드나요? (초보수준의 질문..) (2) | 엘보어 | 2025-05-16 |
2694958 | 로직이 변한다는 것에 대해서 궁금합니다. | 튼동 | 2025-05-16 |
2694929 | 열혈강의 25-2 두번째 문제 질문 | 지우개 | 2025-05-15 |
2694900 | dequeue 에서 리턴값 프린트 방법알려주세요 오늘 12시까지 대화방에 있습니다 도와주세요 | 미투리 | 2025-05-15 |
2694854 | 절대값을 구할때 (2) | 그녀는귀여웠다 | 2025-05-15 |
2694827 | 이제 어떻게 공부해야할지 모르겠네요 | 새얀 | 2025-05-14 |
2694778 | 순열 계산요. | 맛조이 | 2025-05-14 |
2694754 | ShowWindow 함수를 이용하려 하는데 질문있습니다. (2) | 파도 | 2025-05-14 |
2694731 | 리눅스 커널의 시작점 질문 | 미르 | 2025-05-13 |
2694702 | 이거 뭐가문제인가요 코드수정좀 (3) | 맑은 | 2025-05-13 |
2694675 | C언어 후위표기를 중위표기로 | 앨런 | 2025-05-13 |
2694646 | 안녕하세요 파일 합치기 함수! (1) | 연블루 | 2025-05-13 |
2694618 | 잘몰라서 설명부탁드립니다. scanf 관련 (3) | 파라 | 2025-05-12 |
2694590 | 이 코드가 뭐하는 코드일까요? #2 | 빵순 | 2025-05-12 |
2694559 | 동적할당으로 배열(2차원열)을 만드는데 있어 그걸 함수화시키는데... (1) | 늘솔길 | 2025-05-12 |