Problem Solving/Topcoder

SRM 380 Div.2

hongjun7 2016. 4. 22. 16:37


250 : 쉬운 구현 문제

class LuckyTicketSubstring {
public:
	int maxLength(string s) {
		int res = 0;
		int n = s.size();
		for (int i = 0; i < n; i++) {
			int L = 1;
			for (int j = i + 1; j < n; j += 2) {
				int s1 = 0, s2 = 0;
				int i2 = i + L;
				for (int k = 0; k < L; k++) {
					s1 += s[i + k] - '0';
					s2 += s[i2 + k] - '0';
				}
				if (s1 == s2) res = max(res, L * 2);
				L++;
			}
		}
		return res;
	}
};

500 : 오른쪽으로만 이동할 수 있는 연산의 특성을 고려해 케이스를 잘 나누어 Greedy하게 해결하면 됨.

class LameKnight {
public:
	int maxCells(int height, int width) {
		if (height == 1 || width == 1) return 1;
		if (width >= 7) {
			if (height == 2) return 4;
			return width - 2;
		}
		if (width >= 5) {
			if (height == 2) return 3;
			return 4;
		}
		if (width >= 3) {
			if (height == 2) return 2;
			return width;
		}
		if (height == 2) return 1;
		return 2;
	}
};

1000 : tuple의 개수에 대해 parametric search. 처음에 잘못된 그리디로 접근을 해서 고생을 좀 했다. 시간이 지나가면 다시 풀어보아야 할 문제이다.

class CompilingDecksWithJokers {
public:
	int n;
	int f(vector <int> c, int jokers, int X) {
		long long ret = 0;
		for (int i = 0; i < n; i++) {
			if (X >= c[i]) ret += X - c[i];
		}
		return (ret <= jokers && ret <= X);
	}
	int maxCompleteDecks(vector <int> c, int jokers) {
		int res = 0;
		n = c.size();
		if (n == 1) return c[0] + jokers;
		int mn = 1e9;
		for (int i = 0; i < n; i++) mn = min(mn, c[i]);
		int L = 0, R = mn + jokers, M;
		while (L <= R) {
			M = (L + R) / 2;
			if (f(c, jokers, M)) res = max(res, M), L = M + 1;
			else R = M - 1;
		}
		return res;
	}
};