์ด ํฌ์ŠคํŒ…์€ ์ฟ ํŒก ํŒŒํŠธ๋„ˆ์Šค ํ™œ๋™์˜ ์ผํ™˜์œผ๋กœ, ์ด์— ๋”ฐ๋ฅธ ์ผ์ •์•ก์˜ ์ˆ˜์ˆ˜๋ฃŒ๋ฅผ ์ œ๊ณต๋ฐ›์„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

๋ฐ˜์‘ํ˜•
in Judge Queue๋กœ ์ธํ•ด ์•„์ง ํŒ๋‹จ๋ชปํ•œ ๋‚ด๊ฐ€ ํ‘ผ ์†Œ์Šค


2007/2008 ACM International Collegiate Programming Contest
University of Ulm Local Contest

Problem A: Annoying painting tool

Maybe you wonder what an annoying painting tool is? First of all, the painting tool we speak of supports only black and white. Therefore, a picture consists of a rectangular area of pixels, which are either black or white. Second, there is only one operation how to change the colour of pixels:

Select a rectangular area of r rows and c columns of pixels, which is completely inside the picture. As a result of the operation, each pixel inside the selected rectangle changes its colour (from black to white, or from white to black).

Initially, all pixels are white. To create a picture, the operation described above can be applied several times. Can you paint a certain picture which you have in mind?

Input Specification

The input contains several test cases. Each test case starts with one line containing four integers n, m, r and c. (1 โ‰ค r โ‰ค n โ‰ค 100, 1 โ‰ค c โ‰ค m โ‰ค 100), The following n lines each describe one row of pixels of the painting you want to create. The ith line consists of m characters describing the desired pixel values of the ith row in the finished painting ('0' indicates white, '1' indicates black).

The last test case is followed by a line containing four zeros.

Output Specification

For each test case, print the minimum number of operations needed to create the painting, or -1 if it is impossible.

Sample Input

3 3 1 1
010
101
010
4 3 2 1
011
110
011
110
3 4 2 2
0110
0111
0000
0 0 0 0

Sample Output

4
6
-1
๋ฐ˜์‘ํ˜•

์ด ํฌ์ŠคํŒ…์€ ์ฟ ํŒก ํŒŒํŠธ๋„ˆ์Šค ํ™œ๋™์˜ ์ผํ™˜์œผ๋กœ, ์ด์— ๋”ฐ๋ฅธ ์ผ์ •์•ก์˜ ์ˆ˜์ˆ˜๋ฃŒ๋ฅผ ์ œ๊ณต๋ฐ›์„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

๋ฐ˜์‘ํ˜•

First of all, This fuckin' problem doesn't give a importance to ability of solving a problem.
It's rather fucusing on how properly demonstrate on a display.

I almost spend 3hours to make it appropriate for displaying, and it was just 30minutes to figure out the method.

I'll show you a code even if this possibly spoil your creativity. (or Leave this place haha)

๋จผ์ € ์ด ๋งํ•  ๋ฌธ์ œ ํ‘ธ๋Š”๋ฐ ๋‚ด ๋ฌธ์ œํ•ด๊ฒฐ ๋Šฅ๋ ฅ๋ณด๋‹ค๋Š” ์–ด๋–ป๊ฒŒ ํ•˜๋ฉดํ˜•์‹์— ๋งž๊ฒŒ ์ถœ๋ ฅํ• ๊นŒ๊ฐ€ ๋” ๊ด€๊ฑด์ด์—ˆ๋‹ค.
ํ•œ 3์‹œ๊ฐ„์ •๋„ ๋“ค์˜€๋Š”๋ฐ 30๋ถ„์ •๋„๋Š” ์–ด๋–ป๊ฒŒํ•˜๋ฉด ๋ฌธ์ œ๋ฅผ ํ’€๊นŒ์˜€๊ณ  ๋‚˜๋จธ์ง€๋Š” ํ˜•์‹ ๋งž์ถ”๋Š๋ผ ๋…ธ๊ฐ€๋‹ค์งˆ; ;;

์†Œ์Šค์ฝ”๋“œ๋ฅผ ๋ณด์—ฌ๋“œ๋ฆดํ…Œ๋‹ˆ, ํ’€๊ณ ์žˆ๋Š” ์‚ฌ๋žŒ์€ ์Šคํฌ์ผ์„ฑ์ด ๋ ์ˆ˜์žˆ์œผ๋ฏ€๋กœ ๋– ๋‚˜์‹œ์˜น ใ…‹ใ…‹

์†Œ์ŠคํŽผ์น˜๊ธฐ----- 

๋ฐ˜์‘ํ˜•

์ด ํฌ์ŠคํŒ…์€ ์ฟ ํŒก ํŒŒํŠธ๋„ˆ์Šค ํ™œ๋™์˜ ์ผํ™˜์œผ๋กœ, ์ด์— ๋”ฐ๋ฅธ ์ผ์ •์•ก์˜ ์ˆ˜์ˆ˜๋ฃŒ๋ฅผ ์ œ๊ณต๋ฐ›์„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.

๋ฐ˜์‘ํ˜•

๊ฐ‘์ž๊ธฐ ICPCํ•™ํšŒ๊ฐ€ ์ƒ๊ฐ์ด ๋‚˜์„œ ํ•™ํšŒ ํ™ˆํ”ผ๋ฅผ ๋“ค๋ €๋‹ค.

๊ทธ ๋™์•ˆ ํ•™์› ๋‹ค๋‹ˆ๋ฉด์„œ ๋‚ด ์‹ค๋ ฅ์ด ์–ผ๋งˆ๋‚˜ ํ–ฅ์ƒ์ด ๋˜์—ˆ๋‚˜.. ์ ๊ฒ€๋„ ํ•  ๊ฒธ...


์‚ฌ์‹ค ํ•™์›์—์„œ๋Š” ๊ฒŒ์ž„ํ”„๋กœ๊ทธ๋ž˜๋ฐ์ด๋ผ ์ˆ˜ํ•™์ ์ธ ์ƒ๊ฐ๋„ ๋งŽ์ด ํ•ด์•ผํ•˜๊ธด ํ•˜์ง€๋งŒ,

๋ฌธ์ œํ•ด๊ฒฐํ•˜๋Š”๋ฐ ์žˆ์–ด์„œ Uva๋ฌธ์ œ๊ฐ€ ์ข€ ๋” ์งง์€์‹œ๊ฐ„์— ๊ณ ์ˆ˜์ค€์˜ ๋ฌธ์ œํ•ด๊ฒฐ๋Šฅ๋ ฅ์„ ์š”๊ตฌํ•˜๋Š” ํŽธ์ด๋ผ๊ณ  ์ƒ๊ฐํ•œ๋‹ค.


์š” ๋ฌธ์ œ๋ฅผ ํ’€๊ฒŒ๋˜์—ˆ๋‹ค.

10019 - Funny Encryption Method 6366 69.82% 4108 94.94%
http://icpcres.ecs.baylor.edu/onlinejudge/index.php?option=com_onlinejudge&Itemid=8&category=12&page=show_problem&problem=960


ํ ....

์ •๋ง์ด์ง€...

์‹ ๊ธฐํ–ˆ๋‹ค... ๋ญ๊ฐ€?

๊ทธ๋ƒฅ ์ƒ๊ฐ๋‚˜๋Š”๋Œ€๋กœ ์ฝ”๋”ฉ์ด ๋น ๋ฅด๊ฒŒ๋˜์—ˆ๋‹ค. ์˜ˆ์ „๊ฐ™์•˜์œผ๋ฉด ๋ฌธ์ œํ•ด๊ฒฐ๋ฐฉ๋ฒ•์ด ๋จธ๋ฆฟ์†์— ๋งด๋Œ์•„๋„ ์ฝ”๋”ฉ์„ ๋ชปํ•ด์„œ ํ’€์ง€ ๋ชปํ•œ์ ์ด ๋งŽ์•˜๋Š”๋ฐ...


๊ทผ๋ฐ Submit ํ• ๋•Œ mainํ•จ์ˆ˜๋ฅผ int main(void) {return 0;} ์‹์œผ๋กœ ์งœ์ค˜์•ผ์ง€ ๋ฌธ์ œ์ œ์ถœ์‹œ ์—๋Ÿฌ๊ฐ€ ์•ˆ๋‚˜๋Š”๋ฐ,

๊ทธ๊ฑธ ๊นœ๋นกํ•˜๊ณ  void main(void)๋กœ ์ œ์ถœ์„ ํ•ด์„œ ์ด์œ ๋ชจ๋ฅผ ํ‡ด์งœ๋ฅผ ๋งŽ์ด ๋งž์•„ ๋ถ„๋…ธํ•˜๊ณ  ์žˆ์—ˆ๋‹ค.. ๋ฉ์ฒญํ•˜๊ธด... ;;


์•„๋ฌดํŠผ...์‹ค๋ ฅ์ด ๋Š”๊ฑด ํ™•์‹คํ•œ๊ฑฐ ๊ฐ™๋‹ค.(๋ฌธ์ œํ•ด๊ฒฐ๋Šฅ๋ ฅ์ด ์•„๋‹ˆ๋ผ ๋‹จ์ˆœํžˆ ์ฝ”๋”ฉ์‹ค๋ ฅ์ด ๋Š”๊ฑด๊ฐ€....);;;;


10์ง„์ˆ˜ 265๋ฅผ 16์ง„์ˆ˜ 265๋กœ ์ธ์‹ํ•˜๊ฒŒ ํ• ๋ ค๊ณ  ๊ณ ๋ฏผ์„ ํ•˜๋‹ค๊ฐ€

๊ทธ๋ƒฅ 256์„ ๋ฌธ์ž์—ด๋กœ ๋ฐ”๊พผ๋‹ค์Œ 0x๋ฅผ ์™ผ์ชฝ์— ๋ถ™์ด๊ณ  ๊ทธ๊ฑธ ๋‹ค์‹œ

10์ง„์ˆ˜๋กœ ๋ฐ”๊พธ๋Š” ์‹์œผ๋กœ ํ•ด๋ฒ„๋ ธ๋‹ค.^^

์•„๋ž˜๋Š” ๋ฌธ์ œํ‘ผ ์ฝ”๋“œ๋‹ค.



#include <iostream>
#include <stdlib.h>


using namespace std;



int DecimalToBinary(int nData);       //10์ง„์ˆ˜๋ฅผ ์ด์ง„์ˆ˜๋กœ๋ณ€ํ™˜ํ›„ 1๊ฐฏ์ˆ˜๋ฅผ ์นด์šดํŒ…ํ›„ ๋ฆฌํ„ด
int HexaDecimalToBinary(int nData);   //10์ง„์ˆ˜๋ฅผ ์ž…๋ ฅ๋ฐ›์•„ 16์ง„์ˆ˜๋ฌธ์ž์—ด๋กœ๋ณ€ํ™˜ํ•˜์—ฌ DemicalToBinary()ํ˜ธ์ถœ

int main(void)
{

  int    nNumberOfData; //๋ช‡๊ฐœ๋ฅผ ๋ฐ›์„๊นŒ?
  int    *nData;       //๊ฐฏ์ˆ˜๋งŒํผ ๋ฐ์ดํ„ฐ๋ณ€์ˆ˜์ƒ์„ฑ
  int    i;         //Loop์šฉ
  

  //๋ช‡๊ฐœ?
  cin >>   nNumberOfData;


  nData = new int[nNumberOfData];   //์ž…๋ ฅ๋ฐ›์„ ๊ฐฏ์ˆ˜๋งŒํผ intํ˜• ์ƒ์„ฑ

  //๊ฐฏ์ˆ˜๋งŒํผ ๋ฐ์ดํ„ฐ๋ฅผ ์ž…๋ ฅ๋ฐ›์Œ
  for(i = 0; i < nNumberOfData ; i++)
  {
    cin >> nData[i];
  }


  //์ถœ๋ ฅ
  for(i = 0; i < nNumberOfData ; i++)
  {
    cout << DecimalToBinary(nData[i]) << " " << HexaDecimalToBinary(nData[i]) <<endl;
  }
  


  delete [] nData;   //๋ฉ”๋ชจ๋ฆฌํ•ด์ œ

  return 0;

}

//10์ง„์ˆ˜๋ฅผ ์ž…๋ ฅ๋ฐ›์•„ 2์ง„์ˆ˜๋กœ ๋ณ€ํ™˜ํ›„ 1๋งŒ ์นด์šดํŒ…ํ•˜์—ฌ ๋ฆฌํ„ด
int DecimalToBinary(int nData)
{

  int nCount = 0;
  while(true)
  {
    if(nData == 1)
    {
      nCount++;    
      break;
    }
    //nData๋ฅผ 2๋กœ๋‚˜๋ˆ„์—ˆ์„๋•Œ 1์ด๋‚˜์˜ค๋ฉด nCount๋ฅผ 1์ฆ๊ฐ€
    if(nData % 2 == 1)
    {      
      nCount++;
    }
    nData /= 2//nData๋ฅผ 2๋กœ๋‚˜๋ˆ ๋ฒ„๋ฆผ
    
  }

  return nCount;
}

//10์ง„์ˆ˜๋ฅผ ์ž…๋ ฅ๋ฐ›์•„ 16์ง„์ˆ˜๋ฌธ์ž์—ด๋กœ๋ณ€ํ™˜ํ›„ DemicalToBinary()ํ˜ธ์ถœ
int HexaDecimalToBinary(int nData)
{
  
    //16์ง„์ˆ˜๋ฌธ์ž์—ด๋กœ ๋ฐ”๊พผ๋‹ค์Œ ๋‹ค์‹œ 10์ง„์ˆ˜๋กœ๋ณ€ํ™˜ํ•˜์žฅ.
  char szBuf[16];
  sprintf(szBuf,"0x%d",nData);
  nData = strtol(szBuf, NULL, 16);

  return DecimalToBinary(nData);
}
๋ฐ˜์‘ํ˜•

+ Recent posts