Result: 0/10 xsxssssssx (why were there signals?)
I have given up on this one. As a result, I just submitted code that will return C, in hopes that no boxes are formed by the fences for as many test cases as possible.
C++ solutions, both training and real, are posted when possible; they are provided for reference purposes only.
Tuesday, December 18, 2012
December 2012 Bronze Problem 2: Scrambled Letters
Result: 1/10 *xxxxxtttt (5 wrong answers, 4 timeouts)
Wednesday, November 21, 2012
November 2012 Bronze Problem 3: Horseshoes
Result: 8/10 **x***x*** (2 wrong answers)
hshoe.cpp
hshoe.cpp
#include <iostream> #include <fstream> #include <string> #define loopi(x) loopi_start(x,0) #define loopi_start(x,s) for(int i = (s); i < (x); ++i) #define loop_rev(a,x,stop) for(int a = (x); a >= (stop); --a) using namespace std; int N, first_max; int maxlen(string str, int pos, int first = 0, int second = 0, bool starting = true){ if(starting && str[pos] != ')'){ if(str[pos] == '('){ if(++first > N * N / 2) return 0; // too long } else return 0; // fail (already there) } else{ if(str[pos] != ')') return 0; // fail if(++second >= first) return first + second; // completed path starting = false; } // keep going str[pos] = ' '; int best = 0; // left if(pos % N) best = max(best, maxlen(str, pos - 1, first, second, starting)); // right if(pos % N < N - 1 && pos < N * N - 1) best = max(best, maxlen(str, pos + 1, first, second, starting)); // up if(pos >= N) best = max(best, maxlen(str, pos - N, first, second, starting)); // down if(pos < N * (N - 1) - 1) best = max(best, maxlen(str, pos + N, first, second, starting)); return best; } int main() { ofstream fout ("hshoe.out"); ifstream fin("hshoe.in"); // get input fin >> N; first_max = N * N / 2; // and it is truncated down anyways string str; loopi(N){ string tmp; fin >> tmp; str += tmp; } // process int max_length = maxlen(str, 0); // output fout << max_length << '\n'; // cleanup fin.close(); fout.close(); return 0; }
Tuesday, November 20, 2012
November 2012 Bronze Problem 1: Find the Cow!
The contest has ended! I have posted the first solution now.
Result: 9/10 *********t (timeout)
cowfind.cpp
Result: 9/10 *********t (timeout)
cowfind.cpp
Monday, April 23, 2012
1.3 Problem 76: Mixing Milk
Only 2 failures due to the final cost costing the product of the available number and required, not the price and required number.
I didn't use qsort for it like the analysis. It looks like my solution is similar to the good exemplars.
This one is easy, as two farmers selling the same same price could be combined into one "provider" selling both amounts at the same price each. Since this is a greedy match, take as many as possible from the lowest price, and move on to the next expensive, ..., until there's no more.
I didn't use qsort for it like the analysis. It looks like my solution is similar to the good exemplars.
This one is easy, as two farmers selling the same same price could be combined into one "provider" selling both amounts at the same price each. Since this is a greedy match, take as many as possible from the lowest price, and move on to the next expensive, ..., until there's no more.
Friday, April 20, 2012
Problem 90: Dual Palindromes
I accidentally thought it was "dual square palindromes", which made me fail until I noticed it.
This one is the last for Chapter 1's Section 1.2!
This one is the last for Chapter 1's Section 1.2!
Monday, April 16, 2012
Problem 81: Palindromic Squares
This one requires base conversion, but I'm basically testing every square from 1 to 300 (90 000 fits into a 32-bit signed int; no intervention required). I reverse the string and test if it matches. If so, print the number and its palindromic square, in the requested base.
Friday, April 13, 2012
Problem 29: Name That Number
Friday the 13th...
Another first-attempt! w00t again! This one is done differently then their analysis.
C++ allows you to use std::string, so you can check length. The length of the serial must be equal to the name.
Then I "serialize" or "hash" every name that has the same length, and check if it matches the number.
This is better than doing a binary search of each possible number upon the dictionary.
Another first-attempt! w00t again! This one is done differently then their analysis.
C++ allows you to use std::string, so you can check length. The length of the serial must be equal to the name.
Then I "serialize" or "hash" every name that has the same length, and check if it matches the number.
This is better than doing a binary search of each possible number upon the dictionary.
Monday, April 9, 2012
Problem 75: Transformations
Failed a quite few times, as usual...
This one requires a variable-sized matrix to be rotated/flipped. I just had to check every operation in the order provided. The analysis wastes more approximately 7 times memory than mine; thus, I consider mine is better.
This one requires a variable-sized matrix to be rotated/flipped. I just had to check every operation in the order provided. The analysis wastes more approximately 7 times memory than mine; thus, I consider mine is better.
Friday, April 6, 2012
1.2 Problem 101: Milking Cows
I failed this, the first challenge in Section 1.2, a few times. It won't be easy to get another perfect submission, like last time.
This is basically handling timespans, and merging them. Then traverse over them to find the following:
This is basically handling timespans, and merging them. Then traverse over them to find the following:
- The maximum timespan length, and
- The maximum delay between timespans, but not
- between 0 and t[0].start
- between t[n-1].end and infinity
Monday, April 2, 2012
Problem 99: Broken Necklace
First attempt! w00t! For the last Section 1.1 too!
We're clearly supposed to brute-force every possibility.
Just traverse the maximum number of beads from each possible starting point.
We're clearly supposed to brute-force every possibility.
Just traverse the maximum number of beads from each possible starting point.
Friday, March 30, 2012
Problem 109: Friday the Thirteenth
Today is Friday the thirtieth (30th)!
Not that hard, but I somehow misread 1900 as 1990 once...
Simply find the day of week of the 13th day of the next month.
Then count the days that pass with each month mod 7 for the day of the week for the "zero"th day of the next month.
Not that hard, but I somehow misread 1900 as 1990 once...
Simply find the day of week of the 13th day of the next month.
Then count the days that pass with each month mod 7 for the day of the week for the "zero"th day of the next month.
Monday, March 26, 2012
Problem 77: Greedy Gift Givers
I failed 18 times due to division by zero, modulus of zero, etc.
This one is similar to "accounting". Create accounts for everyone, and change their amount of balance from each transaction. Then print everyone's final balances.
I used heap memory allocation, but that doesn't matter much. I just had to prevent null pointers from causing a crash.
This one is similar to "accounting". Create accounts for everyone, and change their amount of balance from each transaction. Then print everyone's final balances.
I used heap memory allocation, but that doesn't matter much. I just had to prevent null pointers from causing a crash.
Friday, March 23, 2012
Problem 108: Your Ride Is Here
This one is also easy! It's too bad I failed a few times due to const-correctness.
You pretty much "hash" each string, as a product of letters, and compare both hashes mod 47. If they match, "GO", otherwise "STAY" and then print a newline.
On second thought, I could have placed the modulus in the s_product function. Then I also realized that it could be put in after each multiplication operation.
You pretty much "hash" each string, as a product of letters, and compare both hashes mod 47. If they match, "GO", otherwise "STAY" and then print a newline.
On second thought, I could have placed the modulus in the s_product function. Then I also realized that it could be put in after each multiplication operation.
Thursday, March 22, 2012
Subscribe to:
Posts (Atom)