진짜 미치겠습니다;;;; 시간이 이상하게 나오네요..
지지않는
제발,,,알려주세요 -ㅁ-;스샷 봐주세요,질문 내용 : 진짜 문제 없이 잘 한거 같은데 시간이 왜 저렇게 나오는걸까요,,,
소스가 조금 길다 싶으면,, 시간측정 부분만이라도 좀 봐주세요..
#includestdio.h
#includestdlib.h
#includetime.h
#includewindows.h
int max1(int i); // iterative 방법으로 최대값 찾는 함수
int max2(int i); // recursion 방법으로 최대값 찾는 함수
int ran[1000];
void main()
{
int i;
file *f;
large_integer freq,sta1,end1,sta2,end2; // 조금더 정밀한 시간측정을 위한 변수 선언
__int64 time1,time2;
double during1,during2;
queryperformancefrequency(&freq);// 시스템의 빈도수 측정
srand ((unsigned int)time(null));
if((f=fopen(ran.txt, w+)) == null){ // ran.txt 파일 불러오기(파일이 존재하지 않으므로 빈 파일을 새로 생성)
printf(파일이 열리지 않습니다.\n);// 단, 파일 처리 종류중 w+를 사용하여 읽기와 쓰기 모두 가능하게 함
exit(1);
}
for(i=0; i1000; i++){
if(i%20==0){ // 정렬을 위해 한 줄당 20개의 숫자 입력
fprintf(f,\n);
}
fprintf(f, %d\t, rand()%10000);// 생성한 수를 불러온 ran.txt 파일에 입력
}
if((f=fopen(ran.txt, r)) == null){ // ran.txt 파일을 읽기전용으로 열기
printf(파일이 열리지 않습니다.\n);
exit(1);
}
for(i=0; i1000; i++){
if(i%20==0){
fprintf(f,\n);
}
fscanf(f, %d, &ran[i]);// ran.txt 파일에 입력되있는 수를 ran[]배열에 저장
}
fclose(f);
printf(\n0~10000 사이의 수 중에서);
queryperformancecounter(&sta1);
printf(\n1. iterative 방법으로 구한 최대값은 %d입니다.\n, max1(0)); // iterative 함수 호출
queryperformancefrequency(&end1);
time1=end1.quadpart-sta1.quadpart;
during1=(double)time1/freq.quadpart;
printf(%lf초 \n, during1);
queryperformancecounter(&sta2);
printf(\n2. recursion 방법으로 구한 최대값은 %d입니다.\n, max2(0)); // recursion 함수 호출
queryperformancefrequency(&end2);
time2=end2.quadpart-sta2.quadpart;
during2=(double)time2/(double)freq.quadpart;
printf(%lf초 \n, during2);
}
int max1(int i)// iterative 방법으로 최대값 찾는 함수
{
int max_num1=ran[0];// 배열의 처음 값을 최대값으로 저장
for(i=1; i1000; i++){// 나머지 값돋潭?값들을 비교해가면서 최대값보다 클 경우
if(max_num1ran[i]){ // 최대값을 갱신
max_num1=ran[i];
}
}
return max_num1;
}
int max2(int i)// recursion 방법으로 최대값 찾는 함수
{
static int j,max_num2=0;// static변수로 max1이 계속 열려도 변동되지않는 변수 생성
if(j999){// j 변수를 통해 1부터 1000개까지의 배열을 비교
j++;
if(ran[i]ran[j]){// 비교 한 뒤에 더 높은 값을 max_num2에 저장
max_num2=j;
return max2(max_num2);// 리턴 시에 max_num2 값을 리턴
}
else{
max_num2=i;
return max2(max_num2);
}
}
else{// 1000개의 배열을 비교한 후에는 최대값으로 남아있는 max_num2 번호를 리턴
return ran[max_num2];
}
}
-
참이
대체 왜 시간이 마이너스가 나오는지,,정말 궁금합니다,
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2695707 | 3의 배수 나타내기. (2) | 수리 | 2025-05-23 |
2695626 | 피보나치수열 과제 때문에 질문 드립니다. (6) | 옆집언니 | 2025-05-22 |
2695595 | 포인트공부중입니다 int형에서 4=1 인가요? (3) | 족장 | 2025-05-22 |
2695567 | 드라이브 고유번호를 가져오는 함수 (2) | 초코맛사탕 | 2025-05-21 |
2695533 | 음수의 산술변환! 질문이요 ㅠㅠ... (4) | 꽃여름 | 2025-05-21 |
2695506 | 구조체 배열 이용 도서목록 출력 프로그램 (1) | 가을귀 | 2025-05-21 |
2695450 | c언어 함수 질문이요.... | 이슬비 | 2025-05-20 |
2695403 | VirtualAlloc함수 및 메모리 질문 | 크리에이터 | 2025-05-20 |
2695355 | c언어 for함수 | 미쿡 | 2025-05-19 |
2695327 | 안녕하세요 제가 이번에 좀 큰 프로그램을.. | 악당 | 2025-05-19 |
2695295 | mutex동기화의 thread기반 채팅 서버소스 질문입니다 | 그루터기 | 2025-05-19 |
2695270 | 질문이요..swap 관한겁니다..ㅠㅠ (3) | 콩알녀 | 2025-05-19 |
2695244 | 노땅초보궁금한게 하나 있는데요..반복문(while문)초보자질문 (6) | 큰꽃늘 | 2025-05-18 |
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 |