时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld
题目描述
在三维空间中,平面 x = 0, y = 0, z = 0,以及平面 x + y + z = K 围成了一个三棱锥。
整天与整数打交道的小明希望知道这个三棱锥内、上整点的数目。
他觉得数量可能很多,所以答案需要对给定的 M 取模。
整天与整数打交道的小明希望知道这个三棱锥内、上整点的数目。
他觉得数量可能很多,所以答案需要对给定的 M 取模。
输入描述:
输入有 1 ≤ T ≤ 105 组数据。 每组数据中,输入两个整数 0 ≤ K ≤ 109 + 7, 1 ≤ M ≤ 109 + 7,意义如题目描述。
输出描述:
对于每组数据,输出一个整数,为三棱锥内、上整点的数目对 M 取模。
题解:
这道题发现很多人都这样做,感觉是什么公式来的,希望有大佬来指点一下,先占个楼。
后补:是这个四面体数!!!超强!!!!
25602597的代码 :
#include<iostream>
using namespace std;
int main(){
int t;
cin>>t;
unsigned long long k,m;
while(t--){
cin>>k>>m;
m*=6;
unsigned long long ans=(k+1)*(k+2)%m*(k+3)%m;
ans=ans/6;
cout<<ans<<endl;
}
return 0;
}