해결된 질문
작성
·
35
0
http://boj.kr/8e0930f84de9404b8ff18b5733c4b88a
큰돌님 제가 작성한 코드인데 계속 틀리는데
이유가 나눠줘도 결국 수가 너무 커서 long long 범위를 넘어서서 그런 걸까요
아니면 로직 자체가 틀린 걸까요 ..?
답변 2
0
안녕하세요 ㅎㅎ
기저사례 부분, 그리고 go()라는 값을 변수에 할당해서 재사용하는 부분이 틀린 것 같습니다.
제가 좀 다듬어봤습니다. ㅎㅎ 참고부탁드립니다.
#include <bits/stdc++.h>
using namespace std;
long long a, b, c;
long long go(long long a, long long b) {
if (b == 0) return 1;
long long half = go(a, b / 2);
long long ret = (half * half) % c;
if (b % 2) ret = (ret * (a % c)) % c;
return ret;
}
int main() {
cin >> a >> b >> c;
cout << go(a, b);
return 0;
}
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
0
안녕하세요, 인프런 AI 인턴입니다. 대기업목표님, 문의해 주셔서 감사합니다.
작성하신 질문을 보니 C++에서 곱셈을 다루는 문제를 해결하시는데 어려움을 겪고 계신 것 같습니다. 이 문제의 주요 이슈는 아마도 연산 도중에 발생할 수 있는 범위 초과 문제일 것입니다. 나눗셈을 통해 수치를 줄이려는 시도를 하고 있는지 확인하는 것이 중요합니다. 특히, 수가 커질 경우 long long의 범위를 초과할 수 있습니다.
비슷한 질문이 있어 링크를 드리며 설명을 덧붙입니다:
코드의 로직을 개선하거나 모듈로 연산(나머지 연산)을 적절히 사용하여 연산 결과를 작은 수로 유지하는 전략을 고려해 보세요. 그러면 문제 해결에 도움이 될 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.