Fotolog

A través del espejo
2010-10-12: A través del espejo
¡La radio habla en binario!
2010-10-10: ¡La radio habla en binario!
Gigaminx (regalo por mi cumple)
2010-09-16: Gigaminx (regalo por mi cumple)
Trini en bici
2010-09-05: Trini en bici
Valporquero
2010-08-28: Valporquero
Mi bici nueva
2010-08-22: Mi bici nueva
Boda de Mario y Ana
2010-08-13: Boda de Mario y Ana
De cañones en Guara
2010-08-07: De cañones en Guara
Trini y Mari en Marbella
2010-08-05: Trini y Mari en Marbella
Trini y Chelo en Tabarca
2010-08-03: Trini y Chelo en Tabarca
Valid XHTML 1.1
Acceder
Volver a la lista de problemas

Cutting Sticks

10003.c

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int len, n;

int cuts[60];
int table[60][60];

int
calc(int beg, int end) {
	int i;
	int min=1000000000;

	if (beg+1==end) {
		return 0;
	}
	if (beg+2==end) {
		return cuts[end]-cuts[beg];
	}
	if (table[beg][end]) {
		return table[beg][end];
	}
	for (i=beg+1; i<end; i++) {
		int cost = calc(beg,i) + calc(i,end);
		if (cost < min) {
			min = cost;
		}
	}
	return table[beg][end] = cuts[end]-cuts[beg] + min;
}

int
main(void) {
	int i;

	while (1) {
		scanf("%d", &len);
		if (len==0) {
			break;
		}
		if (len<0 || len>=1000) abort();
		scanf("%d", &n);
		if (n>=50) abort();

		cuts[0] = 0;
		cuts[n+1] = len;
		for (i=1; i<=n; i++) {
			scanf("%d", &cuts[i]);
			if (cuts[i]<0 || cuts[i]>=len) abort();
		}
		memset(table, 0, sizeof(table));
		printf("The minimum cutting is %d.\n", calc(0, n+1));
	}
	return 0;
}