알고리즘/Codeforces
Ozon Tech Challenge 2020 (Div.1+Div.2) C. Kuroni and Impossible Calculation
세진짱
2020. 3. 10. 18:41
이런 수학문제가 참 어려운거같다 나는
한참 생각하고 틀린 문제다 혼자 식을 줄이려고 애썼는데 안떠오른다..
이 문제는 m이 1000이하인게 힌트다!
먼저 2가지 경우가 있을 수 있다
1. n<=m인 경우
그럼 n의 최댓값이 1000이므로 그냥 n^2으로 직접 구해보면 된다
그래봐야 백만이다!!
2. n>m인 경우
이 경우를 생각도 못했다. 만약 n>m이라면 어떻게 될까?
%m해서 나올 수 있는 값은 총 m개다 근데 m보다 큰 n에 대해 %m을 한다면
비둘기집의 원리에 의해 누군가 하나는 같은게 나올 수 밖에 없다!! 생각도못함..!
같은게있다는말은 빼면 0이된다는 말이고 결국 곱하기 0이 생긴다는거니까 0이다 그냥!
그냥 0..!
수학공부를 다시 해야할까보다..
소스코드
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
#include <bits/stdc++.h>
using namespace std;
#define ll long long
int n,m;
int arr[200020];
int main(){
scanf(" %d %d",&n,&m);
for(int i=0;i<n;i++) scanf(" %d",&arr[i]);
if(n>m) puts("0");
else{
ll ans=1LL;
for(int i=0;i<n;i++){
for(int j=i+1;j<n;j++){
ans*=abs((ll)arr[j]-(ll)arr[i]);
ans%=(ll)m;
}
}
printf("%lld\n",ans);
}
}
|