結果

問題 No.865 24時間降水量
ユーザー butsurizukibutsurizuki
提出日時 2019-08-15 01:45:26
言語 C
(gcc 12.3.0)
結果
AC  
実行時間 87 ms / 2,000 ms
コード長 826 bytes
コンパイル時間 426 ms
コンパイル使用メモリ 30,376 KB
実行使用メモリ 4,348 KB
最終ジャッジ日時 2023-10-19 18:22:52
合計ジャッジ時間 1,661 ms
ジャッジサーバーID
(参考情報)
judge11 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,348 KB
testcase_01 AC 1 ms
4,348 KB
testcase_02 AC 1 ms
4,348 KB
testcase_03 AC 1 ms
4,348 KB
testcase_04 AC 1 ms
4,348 KB
testcase_05 AC 2 ms
4,348 KB
testcase_06 AC 1 ms
4,348 KB
testcase_07 AC 1 ms
4,348 KB
testcase_08 AC 1 ms
4,348 KB
testcase_09 AC 2 ms
4,348 KB
testcase_10 AC 4 ms
4,348 KB
testcase_11 AC 4 ms
4,348 KB
testcase_12 AC 4 ms
4,348 KB
testcase_13 AC 4 ms
4,348 KB
testcase_14 AC 4 ms
4,348 KB
testcase_15 AC 86 ms
4,348 KB
testcase_16 AC 87 ms
4,348 KB
testcase_17 AC 87 ms
4,348 KB
testcase_18 AC 1 ms
4,348 KB
testcase_19 AC 1 ms
4,348 KB
testcase_20 AC 1 ms
4,348 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>

int min(int a,int b){if(a<b){return a;}return b;}
int max(int a,int b){if(a>b){return a;}return b;}

int main(){
  int n,q,i,j,t,v,res=0,nr=0,st,fi;
  int *a=malloc(sizeof(int)*262144);
  scanf("%d",&n);
  assert(24<=n&&n<=200000);
  for(i=1;i<=n;i++){
    scanf("%d",&a[i]);
    assert(0<=a[i]&&a[i]<=153);
  }
  for(i=1;i<=n;i++){
    if(i>24){nr-=a[i-24];}
    nr+=a[i];
    res=max(res,nr);
  }
  scanf("%d",&q);
  assert(1<=q&&q<=200000);
  for(i=0;i<q;i++){
    scanf("%d%d",&t,&v);
    assert(1<=t&&t<=n);
    assert(a[t]<=v&&v<=153);
    a[t]=v;
    st=max(1,t-30);
    fi=min(n,t+30);
    nr=0;
    for(j=st;j<=fi;j++){
      if(j>=st+24){nr-=a[j-24];}
      nr+=a[j];
      res=max(res,nr);
    }
    printf("%d\n",res);
  }
  return 0;
}
0