안녕하세요
2부리거 Rada입니다.
1월 1일 2008년도를 맞이해서 여전히 할 것도 없고, 여자친구마저 없어서 이렇게 문제를 풀어봤습니다.
SRM 383 이구요. 지금 제 컴퓨터가 망가진건지 TC가 이상한건지 Arena가 실행도지 않아서 점수 Point를 정확히 모른채 풀게되서 죄송합니다.
Easy - FloorLayout
한개의 방이 몇개의 파티션으로 나뉘어져 있는 지를 찾아내는 문제입니다.
입력으로는 가로로 나뉘어진 파티션을 의미하는 "-"과
세로로 나뉘어진 파티션을 의미하는 "|"이 들어옵니다.
연속된 -과 |는 하나의 방으로 계산을 하는 문제지요.
[spoiler="풀이보기"]넵. 다들 예상하셨다 싶이 DFS를 묻는 문제입니다.
DFS를 이해하고 있는 분이라면 누구든지 쉽게 풀이하실 수 있지요.
같은 방향으로 이루어진 원소가 더이상 나오지 않을때까지 "-"는 오른쪽 왼쪽으로, "|"는 위쪽, 아래쪽으로 검색해주시고, 방향이 바뀔때마다 카운트를 올려주시면 되겠지요?[/spoiler]
Medium - Pranks
Div1의 Easy와 동일한 문제입니다.
아래 Being님꼐서 설명해주신 http://algospot.com/zbxe/tc/44375 을 참고하세요-*
Hard - HillWalker
"존"이라는 친구가 등산을 하려고 한다네요. 높은 곳을 좋아하는 시간제한(timeToDark)내에 최대한 높은 곳에 갔다가 숙소(0, 0)으로 돌아오고 싶다고 합니다. 근데 이 친구가 은근 약골인지 높이차이(threshold)가 많으면 올라가지 못한다는 군요. 그래서 이 친구를 위해서 프로그램을 작성해주어야 한답니다.
입력으로는 1~26, 27~52까지의 높이를 의미하는 A-Z, a-z로 이루어진 배열과, 높이 차이인 threshold, 제한 시간인 timeToDark가 들어옵니다.
[spoiler="풀이보기"]DIV2지만 그래도 한번쯤 생각해봐야 하는 문제입니다.
저는 Floyd 전쌍최단경로를 이용하였습니다.
landspace를 인접배열방식으로 확장시켜서 한 지점에서 다른 점까지 갈 수 있는지 판단하면서 그래프를 만들어줍니다.
이렇게 생성된 그래프에 Floyd 알고리즘을 적용하면 모든 쌍에 해당하는 최단 거리를 구하실 수 있습니다.
그 후에 모든 쌍에 대해서 Graph[0][n] + Graph[n]0의 값이 timeToDark 이하인 것들 중에서 최고 높이를 찾아주시면 문제가 해결됩니다.
처음에 그래프를 만드실 때 조금만 주의하시면 쉽게 해결하실 수 있을 거라 생각합니다.
소스코드를 첨부하면 아래와 같은데
intmoveX[]={1,-1,0,0};intmoveY[]={0,0,1,-1};classHillWalker{public:intgetHeight(charc){if(c>='A'&&c<='Z')return(int)(c-'A');elsereturn(int)(c-'a')+26;}inthighestPoint(vector<string>landscape,intthreshold,inttimeToDark){inty=landscape.size();intx=landscape[0].size();vector<vector<int>>map(x*y,vector<int>(x*y,timeToDark));inttoX,toY;intrange=0;// make graphfor(inti=0;i<y;i++){for(intj=0;j<x;j++){for(intk=0;k<4;k++){toX=j+moveX[k];toY=i+moveY[k];if(toX<0||toY<0)continue;if(toX>=x||toY>=y)continue;range=getHeight(landscape[i][j])-getHeight(landscape[toY][toX]);if(abs(range)<=threshold){if(range<0)map[i*x+j][toY*x+toX]=range*range;elsemap[i*x+j][toY*x+toX]=1;}}}}// process Floydfor(inti=0;i<x*y;i++)map[i][i]=0;for(inti=0;i<x*y;i++){for(intj=0;j<x*y;j++){for(intk=0;k<x*y;k++){map[j][k]=min(map[j][k],map[j][i]+map[i][k]);}}}//find max_heightintmax_height=-1;for(inti=0;i<y;i++){for(intj=0;j<x;j++){if(map[0][i*x+j]+map[i*x+j][0]<=timeToDark){max_height=max(max_height,getHeight(landscape[i][j]));}}}returnmax_height;}}
make graph 부분에서 floyd 알고리즘을 적용하기 위한 인접배열을 구현하는 방법과
Floyd 알고리즘을 적용하는 부분을 중점적으로 보시면 되실 거라 생각합니다 ^^
[/spoiler]
그럼 새해 복 많이 받으세요~!~!!!!
좀 빠르게 풀어볼려고 recursive하게 풀어봤는데, 최고 430ms 정도가 나오더군요... TLE나도 할말없는 시간... 후덜덜;;;
25*25 배열이 꽤나 크네요;;; 코딩도 알고 짯는데도 500점 정도... 첨본 상태에서 짯으면 당연히 fail ...
언제 1부리그로 올라갈지... @_@
Rada
안녕하세요
2부리거 Rada입니다.
1월 1일 2008년도를 맞이해서 여전히 할 것도 없고, 여자친구마저 없어서 이렇게 문제를 풀어봤습니다.
SRM 383 이구요. 지금 제 컴퓨터가 망가진건지 TC가 이상한건지 Arena가 실행도지 않아서 점수 Point를 정확히 모른채 풀게되서 죄송합니다.
Easy - FloorLayout
한개의 방이 몇개의 파티션으로 나뉘어져 있는 지를 찾아내는 문제입니다.
입력으로는 가로로 나뉘어진 파티션을 의미하는 "-"과
세로로 나뉘어진 파티션을 의미하는 "|"이 들어옵니다.
연속된 -과 |는 하나의 방으로 계산을 하는 문제지요.
[spoiler="풀이보기"]넵. 다들 예상하셨다 싶이 DFS를 묻는 문제입니다.
DFS를 이해하고 있는 분이라면 누구든지 쉽게 풀이하실 수 있지요.
같은 방향으로 이루어진 원소가 더이상 나오지 않을때까지 "-"는 오른쪽 왼쪽으로, "|"는 위쪽, 아래쪽으로 검색해주시고, 방향이 바뀔때마다 카운트를 올려주시면 되겠지요?[/spoiler]
Medium - Pranks
Div1의 Easy와 동일한 문제입니다.
아래 Being님꼐서 설명해주신 http://algospot.com/zbxe/tc/44375 을 참고하세요-*
Hard - HillWalker
"존"이라는 친구가 등산을 하려고 한다네요. 높은 곳을 좋아하는 시간제한(timeToDark)내에 최대한 높은 곳에 갔다가 숙소(0, 0)으로 돌아오고 싶다고 합니다. 근데 이 친구가 은근 약골인지 높이차이(threshold)가 많으면 올라가지 못한다는 군요. 그래서 이 친구를 위해서 프로그램을 작성해주어야 한답니다.
입력으로는 1~26, 27~52까지의 높이를 의미하는 A-Z, a-z로 이루어진 배열과, 높이 차이인 threshold, 제한 시간인 timeToDark가 들어옵니다.
[spoiler="풀이보기"]DIV2지만 그래도 한번쯤 생각해봐야 하는 문제입니다.
저는 Floyd 전쌍최단경로를 이용하였습니다.
landspace를 인접배열방식으로 확장시켜서 한 지점에서 다른 점까지 갈 수 있는지 판단하면서 그래프를 만들어줍니다.
이렇게 생성된 그래프에 Floyd 알고리즘을 적용하면 모든 쌍에 해당하는 최단 거리를 구하실 수 있습니다.
그 후에 모든 쌍에 대해서 Graph[0][n] + Graph[n]0의 값이 timeToDark 이하인 것들 중에서 최고 높이를 찾아주시면 문제가 해결됩니다.
처음에 그래프를 만드실 때 조금만 주의하시면 쉽게 해결하실 수 있을 거라 생각합니다.
소스코드를 첨부하면 아래와 같은데
make graph 부분에서 floyd 알고리즘을 적용하기 위한 인접배열을 구현하는 방법과
Floyd 알고리즘을 적용하는 부분을 중점적으로 보시면 되실 거라 생각합니다 ^^
[/spoiler]
그럼 새해 복 많이 받으세요~!~!!!!
17년 전