CyRhmU.jpeg
查看: 1331  |  回复: 6

cw277

木虫 (正式写手)

[求助] 这样的程序能简化么??

for(IV3=0;IV3<2;IV3++)
                for(IV5=0;IV5<2;IV5++)
                for(IV8=0;IV8<2;IV8++)
                for(IV9=0;IV9<2;IV9++)
                for(IV12=0;IV12<2;IV12++)       
                for(IV14=0;IV14<2;IV14++)
                for(IV18=0;IV18<2;IV18++)
                for(IV24=0;IV24<2;IV24++)
                for(IV26=0;IV26<2;IV26++)
                for(IV36=0;IV36<2;IV36++)
                for(IV46=0;IV46<2;IV46++)
                for(IV48=0;IV48<2;IV48++)
                for(IV55=0;IV55<2;IV55++)
                for(IV71=0;IV71<2;IV71++)
                for(IV80=0;IV80<2;IV80++)
                {
                        for(i=0;i<288;i++)
                        s[ i ]=0;       

                        s[1]=1;

                        s[95] =IV3;
                        s[97] =IV5;
                        s[100] =IV8;
                        s[101] =IV9;
                        s[104] =IV12;
                        s[106] =IV14;
                        s[110] =IV18;
                        s[116] = IV24;
                        s[118] = IV26;
                        s[128] = IV36;
                        s[138] = IV46;
                        s[140] = IV48;
                        s[147] = IV55;
                        s[163] = IV71;
                        s[172] = IV80;
       
                        s[285]=1;
                        s[286]=1;
                        s[287]=1;               
                }

[ Last edited by cw277 on 2012-2-22 at 21:31 ]
回复此楼
感谢生活让我慢慢学会控制自己的情绪,学会包容与忍耐,学会不再去期待
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
回帖置顶 ( 共有1个 )

sudo

木虫 (正式写手)

cw277: 回帖置顶 2012-02-22 23:15:31
jjdg(金币+1): 感谢应助 2012-02-23 09:23:22
从技巧上提示一下楼主吧(不知道是不是对楼主有帮助,毕竟不知道具体任务),如果那些变量都只取0和1然后遍历的话,这不恰好就是一个二进制整数的累加过程?然后下面取变量的值就仅仅用位运算来取出对应位来就可以了

也就是说这个程序可以只用一个循环变量和一个循环递增,里面再用上位运算(使用宏简化它),就得到等价的的简洁程序了

» 本帖已获得的红花(最新10朵)

3楼2012-02-22 23:02:55
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

感谢参与,应助指数 +1
jjdg(金币+1): 感谢应助 2012-02-23 09:23:27
哇靠,这个16重循环看起来很牛叉.
你说说你的问题算了.要不然都不知道怎么化简
matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
2楼2012-02-22 22:50:59
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

cw277

木虫 (正式写手)

送鲜花一朵
引用回帖:
: Originally posted by sudo at 2012-02-22 23:02:55:
从技巧上提示一下楼主吧(不知道是不是对楼主有帮助,毕竟不知道具体任务),如果那些变量都只取0和1然后遍历的话,这不恰好就是一个二进制整数的累加过程?然后下面取变量的值就仅仅用位运算来取出对应位来就 ...

这个有点抽象,麻烦贴出一下程序。  谢谢!
感谢生活让我慢慢学会控制自己的情绪,学会包容与忍耐,学会不再去期待
4楼2012-02-22 23:16:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sudo

木虫 (正式写手)

【答案】应助回帖

感谢参与,应助指数 +1
jjdg(金币+2): 感谢应助 2012-02-23 09:23:53
cw277(金币+7): ★★★很有帮助 谢谢指点! 2012-02-23 09:51:58
引用回帖:
4楼: Originally posted by cw277 at 2012-02-22 23:16:52:
这个有点抽象,麻烦贴出一下程序。  谢谢!

大概是这样的:
CODE:
#include
#include

//注意x为unsigned整型
#define GETBIT(x,n) ( ( (x) & (1<<(n)) ) > 0 )

int main(){
        int i, s[300];
        unsigned int IV;

        for(IV=0; IV<=0x7FFF; IV++){

                for(i=0;i<288;i++) s[i]=0;

                s[1] = 1;

                s[95] = GETBIT(IV, 14);
                s[97] = GETBIT(IV, 13);
                s[100] = GETBIT(IV, 12);
                s[101] = GETBIT(IV, 11);
                s[104] = GETBIT(IV, 10);
                s[106] = GETBIT(IV, 9);
                s[110] = GETBIT(IV, 8);
                s[116] = GETBIT(IV, 7);
                s[118] = GETBIT(IV, 6);
                s[128] = GETBIT(IV, 5);
                s[138] = GETBIT(IV, 4);
                s[140] = GETBIT(IV, 3);
                s[147] = GETBIT(IV, 2);
                s[163] = GETBIT(IV, 1);
                s[172] = GETBIT(IV, 0);

                s[285]=1;
                s[286]=1;
                s[287]=1;
        }
}

如果有bug请自行修正。。。其实这么写更抽象。。。
5楼2012-02-23 08:53:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lt292

金虫 (正式写手)

Holy Shit

lz看看能不能改成递归
可能效率高一点,我也是随便说说
记忆中的颜色,慢慢褪去,变成一缕缕的黑丝,最终消失在茫茫的空白里,一去不返```
6楼2012-02-23 18:30:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sudo

木虫 (正式写手)

引用回帖:
6楼: Originally posted by lt292 at 2012-02-23 18:30:58:
lz看看能不能改成递归
可能效率高一点,我也是随便说说

对于同样级别的算法而言,递归因为多了参数压栈出栈的过程,会比正常的方法慢
7楼2012-02-24 09:39:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 cw277 的主题更新
信息提示
请填处理意见