| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2134 人关注过本帖
标题:请老手帮我看一下这题哦,红色的地方不理解。
取消只看楼主 加入收藏
love04520
Rank: 1
等 级:新手上路
帖 子:16
专家分:5
注 册:2017-6-25
结帖率:66.67%
收藏
已结贴  问题点数:20 回复次数:7 
请老手帮我看一下这题哦,红色的地方不理解。
#include <stdio.h>
int a[1024];
int main(){
    int i , j , n;
    scanf("%d",&n);
    for(i = 0;i < 1<<n;++i)
        a[i] = i;
    for(i = 0;i < n;++i)
        for(j = 0;j < 1<<n;++j)
            if(j>>i&1)
                a[j] += a[j^(1<<i)];
    int sum = 0;
    for(i = 0;i < 1<<n;++i)
        sum += a[i];
    printf("%d\n",sum);
    return 0;
}


搜索更多相关主题的帖子: include 
2017-06-27 00:59
love04520
Rank: 1
等 级:新手上路
帖 子:16
专家分:5
注 册:2017-6-25
收藏
得分:0 
红色的地方不理解什么意思,谁高手说明一下这些是什么意思!谢了。
2017-06-27 01:00
love04520
Rank: 1
等 级:新手上路
帖 子:16
专家分:5
注 册:2017-6-25
收藏
得分:0 
如果输入n为3,那么for(j = 0;j < 1<<n;++j)是不是等价于for(j = 0;j <8;++j)啊,求解
2017-06-27 09:19
love04520
Rank: 1
等 级:新手上路
帖 子:16
专家分:5
注 册:2017-6-25
收藏
得分:0 
唉,竞赛题目,我也想他们好好写啊,可是他们就写成这样,莫办法!
2017-06-27 10:26
love04520
Rank: 1
等 级:新手上路
帖 子:16
专家分:5
注 册:2017-6-25
收藏
得分:0 
a[0]=0,a[1]=1……a[7]=7
for(i = 0;i < n;++i)
        for(j = 0;j < 1<<n;++j)
            if(j>>i&1)
                a[j] += a[j^(1<<i)];

那么接下来的循环:i=0 j=0时,不满足if条件,所以a[0]=0
                      j=1时,不是会满足if条件吗,应当a[1]=a[1]+a[1]=2的呀,为什么这时还是 a[1]=1

不懂,谁帮帮我呀,
2017-06-27 13:23
love04520
Rank: 1
等 级:新手上路
帖 子:16
专家分:5
注 册:2017-6-25
收藏
得分:0 
回复 9楼 九转星河
只需要输入n为3就好了,就是i=0,j=1时 ,为什么a[1]=1,  i=0,j=2时,a[2]=2, i=0,j=3时,为什么a[3]=5,,搞不懂。能说说吗?

2017-06-27 13:46
love04520
Rank: 1
等 级:新手上路
帖 子:16
专家分:5
注 册:2017-6-25
收藏
得分:0 
晕,终于知道错哪了,原来异或是相同为0,相异才为1。。
2017-06-27 13:59
love04520
Rank: 1
等 级:新手上路
帖 子:16
专家分:5
注 册:2017-6-25
收藏
得分:0 
终于知道错在哪里了,按位异或,是相同为0,相异才是1,谢谢大家了。
2017-06-27 14:02
快速回复:请老手帮我看一下这题哦,红色的地方不理解。
数据加载中...
 
   



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

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