My solution for the Problem C "Theme Park" of Google Code Jam 2010 qualification round (in C language):
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int T, t;
int R, k, N;
int r, n, g, peoples, groups;
int Group[1000];
long long Euro;
main() {
long long *Income;
Income = (long long *)malloc(100000000 * sizeof(long long));
if (Income == NULL) {
printf(" -- alloc failed\n");
exit(1);
}
fscanf(stdin, "%d", &T);
for (t = 0; t < T; t++) {
fscanf(stdin, "%d %d %d", &R, &k, &N);
for (n = 0; n < N; n++) {
fscanf(stdin, "%d", &Group[n]);
}
g = 0;
Euro = 0;
for (r = 0; r < R; ) {
for(peoples = groups = 0; (peoples + Group[g] <= k) && (groups < N); groups++ ) {
Euro += Group[g];
peoples += Group[g];
g = (g + 1) % N;
}
Income[r] = Euro;
r++;
if (g == 0) {
Euro = Euro * (R / r);
if ((R % r) > 0) Euro += Income[(R % r) - 1];
break;
}
}
printf("Case #%d: %lld\n", t + 1, Euro);
}
free(Income);
return 0;
}