수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

배열의 값을 검색하여 출력하는 문제 모르겠어요..ㅠㅠ

목화

2025.03.18

질문 제목 : 배열포인터 사용하여 검색하는거 ..질문 내용 :
int linersearch(double *, double key, int size)
: 배열에 key와 동일한 값이 있으면 그 값의 인덱스를 리턴하고 없으면 -1을 리턴 한다.

함수를 이용해서 배열에 있는 값을 찾아

검색하고자하는 값을 입력하시오 : 34.567
값이 존재하지 않습니다?xml:namespace prefix = o /?xml:namespace prefix = o /
검색하고자하는 값을 입력하시오 : 343.54
값이 존재하지 않습니다
검색하고자하는 값을 입력하시오 : 90.04
인덱스 65 에 90.04값이 존재 합니다

이렇게 해줘야 하는데요....
아무리 정확한 값을 넣어 검색해도 값이 존재하지 않는다고만 나와요..ㅜㅜ
제생각엔 무한루프를 계속도는거 아니면
제가 만든 함수에서 검색이 먹히지 않는거 같아요...------------------------------------------아래는 제 c코드 내용입니다-------
(길더라도 양해해 주세요..ㅜㅜ빨간색 친거에서 문제를 찾으면 될거 같아요ㅠㅜ 아무리봐도
뭐가 문제인지 모르겠네요..ㅠㅠ)

#includestdio.h
#define size 100//size변수가 나올 경우 모두 100으로 만드는 문장
#includestdlib.h//난수 만들기 위해 필요한 헤더파일
#includetime.h

void printarray(double *, int size);
void randominputarray(double *, int range, int size);
void changearray(double *, double rate, double key, int size);
void mergearray(double *, double *, int size);
double max(double *, int size);
double min(double *, int size);
int linersearch(double *, double key, int size);

int main()
{
double a[100]={0.0};
double b[100]={0.0};
double res1,res2;//최대, 최소값 저장하는 변수
double sch;//키보드 입력값 저장하는 변수
int res3;//linersearch의 리턴 값 저장하는 변수
//1번 해결
printf(1)\n);
printf(배열a-----------------------------------\n);
randominputarray(a,100,size);//배열 값을 난수로 생성하는 함수
printarray(a,size);//배열 값을 출력해주는 함수
printf(\n);
printf(배열b-----------------------------------\n);
randominputarray(b,100,size);
printarray(b,size);
//2번 해결
printf(2)\n);
printf(배열a-----------------------------------\n);
changearray(a,0.85,50,size);//생성된 배열의 값을 바꾸어 주는 함수
printarray(a,size);//배열 순서에 따라 출력해주는 함수
printf(\n);
printf(배열b-----------------------------------\n);
changearray(b,1.36,20,size);
printarray(b,size);
//3번 해결
printf(3)\n);
printf(배열a-----------------------------------\n);
mergearray(a,b,size);//두 배열을 더하여 첫 번째 배열에 저장함수
printarray(a,size);//배열 값 출력해주는 함수
//4번 해결
printf(4)\n);
res1=max(a,size);
res2=min(a,size);
printf(최대값 :%.2lf \n,res1);
printf(최소값 :%.2lf \n,res2);
//5번 해결
printf(5)\n);
while(1){
printf(검색하고자 하는 값을 입력하세요 :);
scanf(%lf,&sch);
res3=linersearch(a,sch,size);

if(res3!=-1) break;
else if(res3==-1)
printf(값이 존재하지 않습니다\n);

}
printf(인덱스 %d에 %.2lf값이 존재합니다\n,res3,sch);
return 0;
}
void randominputarray(double *ap, int range, int size)
{
int j;
for(j=0; jsize; j++)
{
ap[j]=rand()%range;//포인터 변수 ap에 100이하의 난수 저장
}
}
void printarray(double *i, int size)
{
int k;
for(k=0; ksize; k++)
{
printf(%.2lf\t,*(i+k));
}
}
void changearray(double *ap, double rate, double key, int size)
{
int i;
for(i=0; isize; i++)
{
if(*(ap+i)=key) *(ap+i)=*(ap+i)*rate;
//배열의 값을 조건에 따라 계산하는 반복문
}
}
void mergearray(double *ap, double *bp, int size)
{
int i;
for(i=0; isize; i++)
{
*(ap+i)=*(ap+i)+*(bp+i);
}
}
double max(double *ap, int size)
{
int i;
double max;
max=ap[0];
for(i=0; isize; i++){
if(ap[i]max) max=ap[i];
}
return max;
}
double min(double *ap, int size)
{
int i;
double min;
min=ap[0];
for(i=0; isize; i++){
if(ap[i]min) min=ap[i];
}
return min;
}
int linersearch(double *ap, double key, int size)
{
int i,j;

for(i=0; isize; i++){
if(ap[i]==key) j=i;
else j=-1;
}

return j;
}

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

번호 제 목 글쓴이 날짜
2701754 strcmp,strcpy를 좀더 이해를 하기위해서 간단히 만들었는데... 말달리자 2025-07-17
2701724 배열초기화도중 이니셜라이저 가 너무 많다고 나오네요! (2) 라임나무 2025-07-16
2701697 6.0에서는 잘되던 프로그램이 2008에서는 잘안된답니다. 한번 아시는분 댓글부탁드립니다. (1) 빵순 2025-07-16
2701644 문자가 알파벳인지 검사하기(isalpha) 마음 2025-07-16
2701590 재가 C프로그래밍 아무것도 몰르는데요. (4) 대나무 2025-07-15
2701565 로그인 프로그램 개굴츼 2025-07-15
2701511 이거 오류 안나게 수정좀 부탁드릴께요 ㅠㅠ 돠주세요 ㅠㅠ 어리버리 2025-07-14
2701453 MFC문제점 해결방안좀알려주세요~~ 나샘 2025-07-14
2701429 자료형에 관한 질문 (5) 펴라 2025-07-14
2701377 훌로트형 변수를, 서식문자 %d로 읽기 vs 인트형 포인터로 참조하기 LetMeGo 2025-07-13
2701291 콘솔에서 종료시킬때 메시지를 안띄우려면 어떻게 해야하나요? (1) 세실 2025-07-12
2701262 씨언어 좀 봐주세요 아담 2025-07-12
2701211 토큰추출 겨루 2025-07-12
2701159 연산자문제 알려주세요 도1도캣 2025-07-11
2701130 중적분문제입니다. 적분구간에 변수가 들어갈순 없나요??ㅡㅜ 풀큰 2025-07-11
2701098 난수에 질문드립니다. 큰뫼 2025-07-11
2701070 또다른 시험문제 질문올립니다 채련 2025-07-10
2701042 뭐가 잘못된건지 잘 모르겠습니다.;; 지은 2025-07-10
2700986 뭐가 잘못된건지좀 봐주세요. 우주 2025-07-10
2700932 도와주세요 ㅠㅠ 모르겟어요 ㅠ 유희 2025-07-09
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com