1-N 1629 홀수 일 때의 처리가 이해가 되지 않습니다.
301
작성한 질문수 2
#include <bits/stdc++.h>
using namespace std;
long long A, B, C;
long long go(long long a, long long b)
{
if (b == 1)
{
return a % C;
}
long long ret = go(a, b / 2);
ret = (ret * ret) % C;
if (b % 2 == 1)
{
ret = (ret * a) % C;
}
return ret;
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cin >> A >> B >> C;
cout << go(A, B) << '\n';
}B가 홀 수 일 때, 홀수 처리를 하기 직전
ret = A^(B-1) % C 입니다.
그러면 홀수처리가 진행 될 때
ret = ((A^(B-1) % C) * A) %C 가 코드의 상황 인데 이게 최종 결과인 A^B % C 와 같아지는게 이해가 안됩니다.
나머지 연산의 합동공식이
(a * b) % c = (a % c * b % c) % c 이기 때문에
A^B % C
= (A^(B-1) * A) % C
= (A^(B-1) % C * A % C) % C
위와 같은 식이 나와야 하고
ret = (ret * a) % C가 아니라
ret = (ret * a % C) %C 가 되어야 하는 것 아닌가요? 백준에서는 둘다 맞게 처리 되는데 이해가 되지 않습니다.
답변 1
0
안녕하세요 지훈님 ㅎㅎ
ret = (ret * a) % C가 아니라
ret = (ret * a % C) %C 가 되어야 하는 것 아닌가요?
>>
음... 일단은요.
ret = (ret * ret) % C;
if (b % 2 == 1)
{
ret = (ret * a) % C;
}여기서.. 위쪽 ret은 모듈러 연산이 적용된 것입니다.
따라서
다시 ret에다 모듈러를 할 필요는 없습니다.
그 다음.
(ret * a) % C;a를 곱할 때는 더 큰수가 나올 수 있으니 C를 모듈러를 해줘야 합니다.
또한 지훈님이 지적하신 것처럼 수식을 사용해봤는데요.
이렇게 이해를 하시면 됩니다.

또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
0
아.. 이해 했습니다.
ret이 이미 내부적으로 나머지 연산 처리 된 상태이기 때문에
뒤에 얼마나 추가적인 나머지 연산이 붙어도 상관없어 ret % c == ret이 성립하는 군요..
실제로 둘 다 맞는 방식인 것이군요. 상세한 증명까지 적어주셔서 감사합니다!
코딩살구클럽 입장이 안됩니다
0
3
1
4-F 경우의 수 질문입니다.
0
24
2
코딩살구클럽 가입이 안됩니다.
0
50
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
40
1
교안 158페이지 문의드립니다
0
37
2
코딩살구클럽 관련 건의사항
0
94
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
39
1
진행 방법 질문드립니다!
0
72
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
61
2
2주차 개념#12 트리 순회
0
32
2
백준사이트가 종료된다고 합니다.
0
301
2
백준 서비스 종료
9
913
1
sk 하이닉스 코테 대비
0
377
2
3-G 최댓값 질문
0
52
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
84
2
3-I 코드 질문드립니다.
0
63
2
3-N 질문 있습니다.
0
68
2
학습방법
0
104
2
4-H 질문 있습니다 (코드 리뷰)
0
67
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
178
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
70
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
65
2
1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.
0
52
2
조합 재귀 풀이 확인 해주시면 감사하겠습니다.
0
69
2





