結果
| 問題 |
No.252 "良問"(良問とは言っていない (2)
|
| コンテスト | |
| ユーザー |
goodbaton
|
| 提出日時 | 2015-07-24 23:27:34 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 2,090 bytes |
| コンパイル時間 | 881 ms |
| コンパイル使用メモリ | 83,588 KB |
| 実行使用メモリ | 16,608 KB |
| 最終ジャッジ日時 | 2024-07-08 14:05:01 |
| 合計ジャッジ時間 | 2,629 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 4 WA * 3 |
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:70:10: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
70 | scanf("%d",&T);
| ~~~~~^~~~~~~~~
ソースコード
#include <cstdio>
#include <cstdlib>
#include <iostream>
#include <string>
#include <cmath>
#include <algorithm>
#include <vector>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <cstring>
typedef long long ll;
using namespace std;
#define mod 1000003
#define INF 1000000000
#define LLINF 2000000000000000000LL
#define SIZE 100
struct RMQ{
int segn2,seg[2<<20];
RMQ(){
segn2=0;
}
void init(int n){
segn2=1;
while(segn2<n) segn2*=2;
for(int i=0;i<segn2*2-1;i++)
seg[i]=2147483647;
}
int q(int a,int b,int l=0,int r=-1,int k=0){
if(r<0) r=segn2-1;
if(a<=l && r<=b) return seg[k];
if(r<a || b<l) return 2000000000;
return min(q(a,b,l,(l+r)/2,k*2+1),q(a,b,(l+r)/2+1,r,k*2+2));
}
void set(int k,int x){
k+=segn2-1;
seg[k]=x;
while(k>0){
k=(k-1)/2;
seg[k]=min(seg[k*2+1],seg[k*2+2]);
}
return;
}
};
RMQ rmq2;
int good[1000000];
int main(){
string S;
int T,c,n,ans;
scanf("%d",&T);
for(int i=0;i<T;i++){
ans = INF;
cin >> S;
n = (int)S.size();
for(int i=0;i<n;i++)
good[n]=INF;
rmq2.init(n);
for(int j=0;j<n-3;j++){
c=0;
for(int i=0;i<4;i++){
if(S[j+i]!="good"[i]){
c++;
}
}
good[j]=c;
}
for(int j=0;j<n-6;j++){
c=0;
for(int i=0;i<7;i++){
if(S[j+i]!="problem"[i]){
c++;
}
}
rmq2.set(j,c);
}
for(int i=0;i<n-10;i++){
ans=min(ans,good[i]+rmq2.q(i+4,n-7));
}
printf("%d\n",ans);
}
return 0;
}
goodbaton