| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 958 人关注过本帖
标题:这个是怎样的过程啊
只看楼主 加入收藏
快乐……刘杰
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2017-1-2
结帖率:0
收藏
已结贴  问题点数:20 回复次数:7 
这个是怎样的过程啊
main()
{    int    p[7]={11,13,14,15,16,17,18},i=0,k=0;
    while(i<7&&p[i]%2){k=k+p[i];i++;}
    printf("%d\n",k);
}
过程是怎样实现的?答案不是重点……

2017-01-03 21:14
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:4 
程序代码:
int main(void)
{
    int p[7]={11,13,14,15,16,17,18};
    int i=0;
    int k=0;
    while( i<7 && (p[i]%2)!=0 ) 
    {
        k=k+p[i];
        i++;
    }
    printf("%d\n",k);
    return 0;
}

DO IT YOURSELF !
2017-01-03 21:22
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:4 
(p[i]%2)//等价于(p[i]%2!=0)就是说是求奇数的和咯~~~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-01-03 21:22
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
以下是引用九转星河在2017-1-3 21:22:32的发言:

(p%2)//等价于(p%2!=0)就是说是求奇数的和咯~~~
不全对  你猜猜答案应该是多少呢

DO IT YOURSELF !
2017-01-03 21:29
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
回复 4楼 wp231957
我猜答案是24~
对哦感觉我水了~
当遇到偶数时就终止循环了~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-01-03 21:42
xuruishuai
Rank: 1
等 级:新手上路
帖 子:1
专家分:4
注 册:2017-1-3
收藏
得分:4 
数组就6个元素,你让i恒小于7,及循环7次,则最后一个单元你没有初始化,所以最后一个单元应该是一个随机值。及数组前六项元素为奇数的和,加最后一个单元的待定值(因为其是一个随机值
2017-01-03 21:49
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:4 
遇到偶数跳出,是 24 吧


[fly]存在即是合理[/fly]
2017-01-03 21:57
核心利益
Rank: 2
等 级:论坛游民
威 望:2
帖 子:19
专家分:44
注 册:2016-12-31
收藏
得分:4 
本题的关键是对while(i<7&&p[i]%2)的理解
while(i<7&&p[i]%2)
i<7以保证不越界,配合i++,为遍历数组。
p[i]%2相当于(p[i] % 2!= 0),也就是p[i]不能被2整除。

整个条件含义就是:找到第一个能被2整除的数据,对它前面的数据进行处理
k = k + p[i];
说明处理方式为求和。
所以,结果应为:
11 + 13 =24
2017-01-03 23:00
快速回复:这个是怎样的过程啊
数据加载中...
 
   



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

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