PGR21.com
- PGR21 관련된 질문 및 건의는 [건의 게시판]을 이용바랍니다.
- (2013년 3월 이전) 오래된 질문글은 [이전 질문 게시판]에 있습니다.
통합 규정을 준수해 주십시오. (2015.12.25.)
Date 2024/07/10 00:22:10
Name 마지막처럼
File #1 C언어trouble.png (161.1 KB), Download : 671
Subject [질문] C언어 독학(초보)중인데 다음 코드에 뭐가 문제일까요?


어떤 수 N을 넣었을때 소인수 분해를 시켜주는 함수 soinsu를 만들어서,
예를 들면  제가 268을 넣었을때

---------------
당신이 넣은 수 268의 소인수 분해 form 은 2 * 2 * 67 입니다.
---------------

라고 출력을 하고 싶어서,
첨에는 printf로 한 문장으로 표현하려고 했는데 아예 문장의 내용이 다 씹히고 2 * 2 *67만 나왔구요, 그래서 각각 문장을 분해해서

printf("당신이 입력한 수 %d의 소인수 분해 form = ", input);
soinsu(input);
printf("입니다.);

라고 할려고 했는데 함수가 들어간 부분의 다음 부분은 아예 실행이 안되네요.
( 결과가
-------
당신이 넣은 수 268의 소인수 분해 form = 2 * 2 * 67
-------
여기까지만 나오고 뒤의 입니다는 안나옵니다.


제 짧은 지식으로는 도저히 원인을 알 수가 없어서 이렇게 질문 드립니다.

통합규정 1.3 이용안내 인용

"Pgr은 '명문화된 삭제규정'이 반드시 필요하지 않은 분을 환영합니다.
법 없이도 사는 사람, 남에게 상처를 주지 않으면서 같이 이야기 나눌 수 있는 분이면 좋겠습니다."
소주파
24/07/10 00:32
수정 아이콘
C는 잘 못합니다만.... for(;;)면 무한반복이라 대신에 소인수분해가 종료되는 조건이 들어가야 될 겁니다. while (N > 1) { 로 바꾸면 어떨지요?
24/07/10 00:34
수정 아이콘
디버깅에 대해 알아보실 딱 적절한 타이밍 같아요.
21번줄에 브레이크포인트를 잡는 법을 알아보시고, 디버그 모드로 실행하는 법을 알아보시고, 한줄 한줄 실행하는 법, 함수 호출하는 줄에선 함수 내부로 디버깅을 타고 들어가는법
을 알아보셔서 내 코드가 한줄 한줄 어떻게 돌아가는지 파악하시고 나면
문제점이 보이실겁니다.
갤럭시S24
24/07/10 02:30
수정 아이콘
(수정됨) 맨 밖의 무한 for(;;) 문은 내부 for 문의 break 로는 나갈 수 없습니다.
이 부분이 님의 코드가 67에서 멈춘 이유입니다.

그 아래 break는 else 문 안쪽으로 이동하시고요. 이것 때문에 밖의 무한 for(;;)와 연계되어
2*2*67까지는 나온 것이긴 합니다만 for문을 두 개 쓰기보다 한 개만 쓰고 종료될 시점에 break를 쓰는게 좋습니다.
else 문 안쪽인 이유는 n이 i로 나누어 떨어졌을 떄 n이 i인 경우는 마지막 소수이기 때문입니다.

그리고 맨 아래 i = 2 로 하면 알고리즘 연산 상 시간 낭비 비효율적인 코드입니다.
i-- 로 바꿔주셔야 합니다. 이로 인해 외부 for(;;)는 없어도 계속 연산이 가능하고요.

따라서 for 문을 아래와 같이 바꾸면 정상 작동할 것입니다.


for (let i = 2; i<= n; i++) {
 if (n % i == 0) {
  if (n != i) printf("%d * ", i);
  else {
   printf("%d", i);
   break;
  }
   n = n/i;
   i--;
 }
}
24/07/10 09:13
수정 아이콘
답변은 윗분들이 잘 해주셨고, 별개로 이런 질문은 AI가 기가막히게 답해줍니다.
질문 많이 하시는거 아니면 무료버전으로도 충분합니다.
ChatGPT나 Claude.ai 써보세요
아래는 Claude 답변입니다.

[네, 이 코드의 주요 문제점들을 해결하는 방법을 설명해드리겠습니다:

무한 루프 문제:
soinsu 함수의 무한 루프로 인해 마지막 printf가 실행되지 않습니다. 이를 해결하기 위해 적절한 종료 조건을 추가해야 합니다.
함수 반환값 미사용:
soinsu 함수가 의미 없는 0을 반환하고 있습니다. 이를 void 함수로 변경하거나, 유용한 정보를 반환하도록 수정해야 합니다.
비효율적인 알고리즘:
현재 알고리즘은 불필요한 반복을 수행합니다. 최적화가 필요합니다.
출력 형식:
마지막 인수 뒤에 불필요한 '*'가 출력되는 문제가 있습니다.

이러한 문제점들을 해결한 개선된 코드는 다음과 같습니다:
(수정 코드 생략...)]
43년신혼1년
24/07/10 11:28
수정 아이콘
위 코드를 그대로 사용하고 싶으시다면
else {
printf("%d", i);
return 0;
}
이렇게 하면 마지막 숫자를 출력한 뒤 함수에서 벗어나게 됩니다.
GregoryHouse
24/07/11 09:26
수정 아이콘
break 관련된 부분은 윗분들이 설명해주셨고
소인수분해 자체의 구조를 개선하시는 게 좋습니다
이 경우에는 for문보다 while문이 보다 유용할 수 있습니다
아래 코드는 예시입니다.

int div=2
while(n>1)
 if(n%div==0)
   //출력관련구문
   n =n/div;
 else
   div++;
마지막처럼
24/07/11 21:15
수정 아이콘
답변 주신 분들 감사합니다.
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
177247 [질문] 모니터링 헤드폰 추천 부탁드립니다. [4] 난키군2133 24/07/25 2133
177246 [질문] 자가용으로 인천공항에 새벽4시에 도착하는 사람을 마중나가야 하는데 어떻게 해야할까요 [15] EnergyFlow4402 24/07/25 4402
177245 [질문] pc견적 한번 부탁드립니다. [3] 투반2342 24/07/25 2342
177244 [질문] 차량손괴를 당했고, 범인을 잡았습니다. [16] 꽃비4193 24/07/25 4193
177243 [질문] 해피머니 어떻게 될까요? [6] 로각좁2893 24/07/25 2893
177242 [질문] 요즘 속초 해수욕장에서 혹시 폭죽 놀이 되나요? [5] 빼사스2562 24/07/25 2562
177241 [질문] 신축입주시 준비사항과 인테리어 [11] 굿리치[alt]2313 24/07/25 2313
177240 [질문] 컴퓨터 이렇게 사도 될까요? [11] 이과감성2312 24/07/25 2312
177239 [질문] 화성,수원,용인 자동차 유리복원 괜찮은곳 궁금합니다 [5] 마스쿼레이드2949 24/07/25 2949
177238 [질문] 강남에 브레이크타임 없고 콜키지 되는 전집이 있을까요? [7] 시은3055 24/07/25 3055
177237 [질문] 녹차패트병의 성분(티백vs패트병) [6] 꿀행성2677 24/07/24 2677
177236 [질문] 수출기업과 내수기업의 경제 기여도 [22] 콩알이3447 24/07/24 3447
177235 [질문] 스톰게이트 질문 [2] Love.of.Tears.2902 24/07/24 2902
177234 [질문] 프로야구 원정팬분들은 시리즈 3일 동안 연고지에서 왔다갔다하시는 건가요? [10] 시나브로3126 24/07/24 3126
177233 [질문] 1세대 크롬캐스트 쓸 수 있는 방법이 있을까요? [3] ...And justice2443 24/07/24 2443
177232 [질문] 공감클럽이라는 회원제몰 아시는 분 계신가요? [2] 루크레티아2658 24/07/24 2658
177231 [질문] 차 트렁크 수리 어떻게 해야 할까요? [9] 프라임에듀2608 24/07/24 2608
177230 [질문] 큐텐에 적립금 탈출해야할까요? + 추천물품 [13] 아이스크림3082 24/07/24 3082
177228 [질문] 에버랜드 9월이나 10월 중 평일 언제가 방문하기 좋을까요 [14] 소이밀크러버2479 24/07/24 2479
177227 [질문] 미국에서 해병대 이미지? [5] 必要韓紙2929 24/07/24 2929
177226 [질문] 원드라이브 공유 문제 허락해주세요2211 24/07/24 2211
177225 [질문] 독서할때 소화력? 질문입니다. [26] 대단하다대단해2945 24/07/24 2945
177224 [질문] 서프샤크 vpn 토렌트 다운시 속도가 너무 느리거나 아예 배포가 안올라갑니다. [8] 그때가언제라도2355 24/07/24 2355
목록 이전 다음
댓글

+ : 최근 1시간내에 달린 댓글
+ : 최근 2시간내에 달린 댓글
맨 위로