| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1664 人关注过本帖
标题:【求助】关于尺子与刻度的问题
只看楼主 加入收藏
mandown1991
Rank: 4
等 级:业余侠客
帖 子:262
专家分:252
注 册:2011-3-2
结帖率:100%
收藏
已结贴  问题点数:15 回复次数:15 
【求助】关于尺子与刻度的问题
原题目:一根29cm长的尺子,只允许在它上面刻7个刻度。若要用它能量出1-29cm的各种整长度,刻度应如何选择?
请教各位前辈,小弟对这道题目的理解确实有限,而且这道题目要求用重复结构完成,小弟学艺尚浅,请各位赐教,谢谢!
补充一下:能不用数组尽量不用,题目要求用for循环的穷举算法!

[ 本帖最后由 mandown1991 于 2011-4-25 12:16 编辑 ]
搜索更多相关主题的帖子: 尺子 而且 如何 
2011-04-24 01:31
qq1023569223
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:湖南科技大学
等 级:贵宾
威 望:26
帖 子:2753
专家分:13404
注 册:2010-12-22
收藏
得分:2 
7个数任意组合能够加到1-29内的所有的数!

   唯实惟新 至诚致志
2011-04-24 07:49
hjywyj
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:3
帖 子:1114
专家分:2611
注 册:2010-4-14
收藏
得分:2 
应该是1,2,3,4,5,6,7吧?
2011-04-24 08:04
mandown1991
Rank: 4
等 级:业余侠客
帖 子:262
专家分:252
注 册:2011-3-2
收藏
得分:0 
求高手!
2011-04-24 12:33
yxwsbobo
Rank: 5Rank: 5
等 级:职业侠客
帖 子:345
专家分:306
注 册:2007-10-29
收藏
得分:2 
应该有测几次的条件,否则的话1个1CM的刻度就够了

How are you 怎么是你?
How old are you   怎么老是你?
2011-04-24 13:40
mandown1991
Rank: 4
等 级:业余侠客
帖 子:262
专家分:252
注 册:2011-3-2
收藏
得分:0 
回复 5楼 yxwsbobo
确实题目没有给出测几次的条件,那么这么说的话应该是这道题目出的不好咯!
2011-04-24 13:57
xdzsm
Rank: 2
等 级:论坛游民
帖 子:137
专家分:99
注 册:2010-10-26
收藏
得分:2 
0 1 2 4 8 16 29   
      

[ 本帖最后由 xdzsm 于 2011-4-24 16:26 编辑 ]
2011-04-24 16:22
voidx
Rank: 12Rank: 12Rank: 12
来 自:邯郸
等 级:火箭侠
帖 子:1250
专家分:3538
注 册:2011-4-7
收藏
得分:2 
应该是一次吧。我是在想不到别的办法,于是就暴力了。下面的代码可以找到全部可能的组合,不过这个运行时间嘛~

程序代码:
#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
kami_dante
Rank: 2
等 级:论坛游民
帖 子:37
专家分:93
注 册:2010-12-29
收藏
得分:2 
这个问题等价于求一个s[7]使s[i],29-s[i],s[i]-s[j]  (0<=j<i<8)遍历[1,28]

[ 本帖最后由 kami_dante 于 2011-4-24 21:22 编辑 ]
2011-04-24 21:21
mandown1991
Rank: 4
等 级:业余侠客
帖 子:262
专家分:252
注 册:2011-3-2
收藏
得分:0 
回复 8楼 voidx
谢谢你的回复,如果不用数组用for循环的穷举能不能算啊!
2011-04-25 12:17
快速回复:【求助】关于尺子与刻度的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.022747 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved