标题:这个程序的每一步到底是为啥呢,我想知道每一步的缘由
只看楼主
呜呜呜嗷嗷嗷
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2012-6-19
结帖率:0
已结贴  问题点数:20 回复次数:4 
这个程序的每一步到底是为啥呢,我想知道每一步的缘由
帮我看看这个程序每一步的缘由,谢谢
#include <stdio.h>
#include <string.h>
#include <algorithm>
#define OP(o)   do { a[1].n = a[0].n o a[1].n; \
        sprintf(a[1].s, "(%s"#o"%s)", a[0].s, strcpy(t.s, a[1].s)); \
        if (dfs(n - 1, a + 1, r)) return 1; \
        a[1] = temp; } while (0)
struct data {
    double n;
    char s[90];
}num[4], t;

int dfs(int n, data a[], double r) {
    int i, j;
    if (n == 1)
        if (a[0].n - r > 1e-8 || a[0].n - r < -1e-8)
            return 0;
        else return 1;
    for (i = 0; i < n; ++i) {
        std::swap(a, a[0]);
        for (j = 1; j < n; ++j) {
            std::swap(a[j], a[1]);
            data temp = a[1];
            OP(+);
            OP(-);
            OP(*);
            if (a[1].n > 1e-8 || a[1].n < -1e-8)
                OP(/);
            std::swap(a[j], a[1]);
        }
        std::swap(a, a[0]);
    }
    return 0;
}

int main() {
    for (int r = 24; ; ) {
        for (int i = 0; i < 4; ++i) {
            scanf("%s", num.s);
            sscanf(num.s, "%lf", &num.n);
        }
        if (dfs(4, num, r))
            printf("%s = %d\n", num[3].s, r);
        else
            printf("No answer\n");
    }
    return 0;
}
搜索更多相关主题的帖子: double include return 
2012-06-19 16:42
zklhp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:china
等 级:贵宾
威 望:254
帖 子:11485
专家分:33241
注 册:2007-7-10
得分:10 
        std::swap(a, a[0]);

感觉像是C++
2012-06-19 16:43
呜呜呜嗷嗷嗷
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2012-6-19
得分:0 
回复 2楼 zklhp
对啊 可是看不懂
2012-06-19 16:47
逸枫
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:33
专家分:113
注 册:2012-6-10
得分:10 
回复 3楼 呜呜呜嗷嗷嗷
C++不是在别的版块吗
2012-06-19 18:00
呜呜呜嗷嗷嗷
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2012-6-19
得分:0 
回复 4楼 逸枫
就是看不懂
2012-06-19 18:11



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-371887-1-1.html




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

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