質問内容
AtCoderの過去問を解いていて,答えが一致するが実行時間が制限以内でない判定を受けてしまったので解説を見てみたのですが,
西から i 番目の人がリーダーになった際、向く方向を変える必要のある人は、西から j(j < i) 番
目に並んでいて西を向いている人と、西から j(j > i) 番目に並んでいて東を向いている人です。
ここで、「ある範囲に存在する西 (東) を向いている人の人数」は、累積和を使うと、前処理 O(N)
時間、1 クエリあたり O(N) 時間で求められます。
よって、まず最初に O(N) 時間で累積和を求めておくと、各人について、その人がリーダーに
なった際に向く方向を変える必要のある人の人数を求めることが O(1) 時間ででき、合計 O(N) 時
間で全員分求まります。あとはその中で最小値を求めればよいです。
とあって累積和を使うとうまくいくそうなのですが,どのような実装の仕方をすればいいのか教えていただきたいです.自分で考えたものを以下に載せますが,これが自分的には累積和になっているのではないかと思ってしまっているので,なにが累積和とは違うのか教えていただきたいです.
C
1for(int i=0;i<N;i++){ 2 if(str[i]=='W'){ 3 for(int j=i+1;j<N;j++) count[j]++; 4 } 5 else{ 6 for(int j=0;j<i;j++) count[j]++; 7 } 8 }
コード全体
C
1#include<stdio.h> 2#include<stdlib.h> 3int main(void){ 4 int N; 5 char *str; 6 int *count; 7 int min; 8 scanf("%d",&N); 9 min=N; 10 str=(char *)malloc(sizeof(char)*N); 11 count=(int *)malloc(sizeof(int)*N); 12 scanf("%s",str); 13 //printf("%s\n",str); 14 15 for(int i=0;i<N;i++) count[i]=0; 16 17 for(int i=0;i<N;i++){ 18 if(str[i]=='W'){ 19 for(int j=i+1;j<N;j++) count[j]++; 20 } 21 else{ 22 for(int j=0;j<i;j++) count[j]++; 23 } 24 } 25 26 for(int i=0;i<N;i++){ 27 if(min>count[i]) min=count[i]; 28 } 29 printf("%d\n",min); 30 31 return 0; 32}
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/08/05 01:56