首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >布尔逻辑问题--两种不同的方法

布尔逻辑问题--两种不同的方法
EN

Stack Overflow用户
提问于 2020-06-14 04:40:55
回答 1查看 52关注 0票数 0

我想出了两种不同的解决问题的方法,虽然这两种方法看起来都合乎逻辑,但只有一种有效。基本上,如果所有未被淘汰的剩余候选人获得相同的最小票数,该函数将返回true,否则返回false。这两种方法如下:

1

代码语言:javascript
复制
bool is_tie(int min)
{
    for (int i = 0; i < candidate_count; i++)
    {
        if (!candidates[i].eliminated)
        {
            if (candidates[i].votes != min)
                return false;
        }
    }
    return true;   
}

2

代码语言:javascript
复制
bool is_tie(int min)
{
    for (int i = 0; i < candidate_count; i++)
    {
        if (!candidates[i].eliminated)
        {
            if (candidates[i].votes == min)
                return true;
        }
    }
    return false;   
}

我看不出上面两个代码函数之间有什么逻辑上的区别。那么为什么2号是错的呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-06-14 06:22:51

如果任何一个候选人投了除最小值之外的任何票数,则标记为1的代码将返回false。

如果任何一个候选人投了最小值,则标记为2的代码将返回true。

因此,考虑有两个候选人的情况,一个人投了最低票,另一个人没有投,你标记为1的代码返回false,因为一个候选人投了最低票而不是最低票。标记为2的代码返回true,因为有一个候选人投了最低票。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62365322

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档