結果
| 問題 | No.5002 stick xor | 
| コンテスト | |
| ユーザー |  tails | 
| 提出日時 | 2018-05-26 01:00:26 | 
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 9 ms / 1,000 ms | 
| コード長 | 1,142 bytes | 
| コンパイル時間 | 1,731 ms | 
| 実行使用メモリ | 1,336 KB | 
| スコア | 883 | 
| 最終ジャッジ日時 | 2018-05-26 01:00:33 | 
| ジャッジサーバーID (参考情報) | judge7 / | 
| 純コード判定しない問題か言語 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 32 | 
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:20:5: warning: ‘char* gets(char*)’ is deprecated (declared at /usr/include/stdio.h:638) [-Wdeprecated-declarations]
     gets(a[y]);
     ^
main.cpp:20:14: warning: ‘char* gets(char*)’ is deprecated (declared at /usr/include/stdio.h:638) [-Wdeprecated-declarations]
     gets(a[y]);
              ^
/tmp/ccaUo2EB.o: In function `main':
main.cpp:(.text.startup+0x147): warning: the `gets' function is dangerous and should not be used.
            
            ソースコード
#include <cstdio>
#include <cstdlib>
#include <algorithm>
using namespace std;
int n,k;
int la[500],li[500];
int ry[500],rx[500];
char a[64][64];
int dbg_sc;
main(){
  scanf("%d%d",&n,&k);
  for(int i=0;i<k;++i){
    scanf("%d ",&la[i]);
    li[i]=i;
  }
  sort(li,li+k,[](int a,int b){return la[b]<la[a];});
  for(int y=0;y<n;++y){
    gets(a[y]);
    for(int x=0;x<n;++x){
      a[y][x]&=1;
    }
  }
  for(int i=0;i<k;++i){
    int l=la[li[i]];
    int by,bx;
    int bs=-30;
    for(int y=0;y<n;++y){
      int s=0;
      for(int x=0;x<l;++x){
        s+=a[y][x]*2-1; 
        a[y][x]^=1;
      }
      for(int x=l;x<=n;++x){
        if(bs<s){
          bs=s; by=y; bx=x;
        }
        s+=a[y][x]*2-1; 
        a[y][x]^=1;
        s+=a[y][x-l]*2-1;
        a[y][x-l]^=1;
      }
      for(int x=n-l+1;x<n;++x){
        a[y][x]^=1;
      }
    }
    //printf("i=%d l=%d bs=%d\n",li[i],l,bs);
    //dbg_sc+=bs;
    ry[li[i]]=by;
    rx[li[i]]=bx;
    for(int x=bx-l;x<bx;++x){
      a[by][x]^=1;
    }
  }
  //printf("score=%d\n",dbg_sc);
  for(int i=0;i<k;++i){
    printf("%d %d %d %d\n",rx[i]-la[i]+1,ry[i]+1,rx[i],ry[i]+1);
  }
}
            
            
            
        