結果

問題 No.3054 Modulo Inequalities
ユーザー lishujia090623
提出日時 2025-09-04 17:15:19
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 1,020 ms / 2,500 ms
コード長 681 bytes
コンパイル時間 1,962 ms
コンパイル使用メモリ 193,972 KB
実行使用メモリ 85,832 KB
最終ジャッジ日時 2025-09-04 17:15:53
合計ジャッジ時間 32,998 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 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]);
      |                 ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~

ソースコード

diff #

#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]);
	}
	for(int i=1;i<=3e6;i++)
		if(mx==w[i])
		{
			printf("%lld",i);
			return 0;
			ans+=i;
		}
	return 0;
}

0