結果
問題 |
No.648 お や す み
|
ユーザー |
|
提出日時 | 2021-08-25 11:24:12 |
言語 | C (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 1 ms / 2,000 ms |
コード長 | 336 bytes |
コンパイル時間 | 1,031 ms |
コンパイル使用メモリ | 28,160 KB |
実行使用メモリ | 6,824 KB |
最終ジャッジ日時 | 2024-11-16 09:39:06 |
合計ジャッジ時間 | 3,166 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 84 |
ソースコード
#include<stdio.h> #include<limits.h> typedef long long ll; ll N; int chk(ll x){ ll sm=x*(x+1)/2; return sm<=N; } int main(){ scanf("%lld",&N); ll ok=0,ng=INT_MAX; while(ok+1!=ng){ ll x=(ok+ng)/2; if(chk(x)) ok=x; else ng=x; } if(N==ok*(ok+1)/2){ printf("YES\n%lld",ok); } else{ printf("NO"); } }