|시간 제한||메모리 제한||제출||정답||맞힌 사람||정답 비율|
|1 초||128 MB||74||57||53||76.812%|
Before you can build oil rigs that will explode and cause huge oil spills, you first need to actually find some oil. Granted, the building and exploding part would theoretically work out without oil, but to produce an oil spill, you really do need oil. Being concerned mostly with costs and profits, the companies want to find oil they can extract as cheaply as possible. While there are other factors involved, a major component of price is how deep one needs to drill to find oil, and through what material. For this problem, we are ignoring just how large certain oil reservoirs are. You will be given a map of the seafloor, and asked to calculate the costs of drilling at the different points.
The first line is the number K of input data sets, followed by the K data sets, each of the following form:
The first line of each data set contains two integers 1 ≤ h,w ≤ 40. Those are the height and width of the seafloor map, respectively. This is followed by h lines, each a string of w upper-case characters. Each letter of the string will be either an ‘X’ (indicating the presence of oil at that location), an ‘H’ (indicating hard rock), or an ‘S’ (indicating soft rock). Drilling through hard rock costs 3 per unit of rock, and drilling through soft rock costs 1 per unit. For each of the w positions, you are to compute how much it will cost to drill straight down from the top until the first oil is hit. In some positions, you might not hit any oil, in which case you should output the letter ‘N’ instead of a cost.
For each data set, output “Data Set x:” on a line by itself, where x is its number. On the next line, output the w costs for drilling to oil at the w positions, in left-to-right order, and separated by a single space each (with no space at the end of the line). If no oil is available at position w, output ‘N’ for that position instead. Each data set should be followed by a blank line.
2 1 1 H 3 5 XXHSS XHSSX XHXSS
Data Set 1: N Data Set 2: 0 0 4 N 1