結果
| 問題 |
No.3054 Modulo Inequalities
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2025-09-04 17:12:35 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 716 bytes |
| コンパイル時間 | 2,262 ms |
| コンパイル使用メモリ | 193,004 KB |
| 実行使用メモリ | 85,712 KB |
| 最終ジャッジ日時 | 2025-09-04 17:13:19 |
| 合計ジャッジ時間 | 37,640 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | WA * 31 |
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:8:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
8 | scanf("%lld",&n);
| ~~~~~^~~~~~~~~~~
main.cpp:11:22: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
11 | scanf("%lld%lld",&a[i],&b[i]);
| ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
ソースコード
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int N=3e6+5;
int n,mx,ans,a[N],b[N],s[N],t[N],w[N],num,sum1,sum2;
signed main()
{
scanf("%lld",&n);
for(int i=1;i<=n;i++)
{
scanf("%lld%lld",&a[i],&b[i]);
s[a[i]]++,s[b[i]]--,num+=(a[i]<b[i]);
if(a[i]>=b[i])s[a[i]-b[i]]--;
else t[b[i]-a[i]]--;
}
for(int i=1;i<=3e6;i++)s[i]+=s[i-1],t[i]+=t[i-1];
sum1=s[(int)3e6],sum2=t[(int)3e6];
for(int i=1;i<=3e6;i++)
{
for(int j=1;i*(j-1)<=3e6;j++)
{
if(i*j-1<=3e6)w[i]+=sum1-s[i*j-1];
w[i]-=(sum2-t[i*(j-1)]);
}
mx=max(mx,w[i]);
}
if(mx==num)
{
printf("%lld -1",mx);
return 0;
}
for(int i=1;i<=3e6;i++)if(mx==w[i])ans+=i;
printf("%lld %lld",mx,ans);
return 0;
}