【求助】关于尺子与刻度的问题
原题目:一根29cm长的尺子,只允许在它上面刻7个刻度。若要用它能量出1-29cm的各种整长度,刻度应如何选择?请教各位前辈,小弟对这道题目的理解确实有限,而且这道题目要求用重复结构完成,小弟学艺尚浅,请各位赐教,谢谢!
补充一下:能不用数组尽量不用,题目要求用for循环的穷举算法!
[ 本帖最后由 mandown1991 于 2011-4-25 12:16 编辑 ]
2011-04-24 01:31
2011-04-24 07:49
2011-04-24 08:04
2011-04-24 12:33
2011-04-24 13:40
2011-04-24 13:57
2011-04-24 16:22
程序代码:#include <stdio.h>
#include <string.h>
int main() {
int a[9], b[30] = {0}, i, j, k = 0;
a[0] = 0;
a[8] = 29;
for (a[1] = 1; a[1] < 23; a[1]++) {
for (a[2] = a[1] + 1; a[2] < 24; a[2]++) {
for (a[3] = a[2] + 1; a[3] < 25; a[3]++) {
for (a[4] = a[3] + 1; a[4] < 26; a[4]++) {
for (a[5] = a[4] + 1; a[5] < 27; a[5]++) {
for (a[6] = a[5] + 1; a[6] < 28; a[6]++) {
for (a[7] = a[6] + 1; a[7] < 29; a[7]++) {
memset(b, 0, sizeof(int) * 30);
for (i = 0; i < 8; i++) {
for (j = i + 1; j < 9; j++) {
b[a[j] - a[i]] = 1;
}
}
for (i = 1; i < 30 && b[i]; i++);
if (i == 30) {
for (i = 1; i < 8; i++) {
printf("%d ", a[i]);
}
printf("\n");
}
}
}
}
}
}
}
}
printf("Done.");
return 0;
}
2011-04-24 19:50
2011-04-24 21:21
2011-04-25 12:17