首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C++中的矢量平衡点函数

C++中的矢量平衡点函数
EN

Stack Overflow用户
提问于 2014-10-14 21:32:49
回答 1查看 320关注 0票数 1

所以我想清除我的C++技能的锈蚀,并认为我应该从一个相当简单的东西开始。大小为N的向量A中的平衡点是K点,使得:a+ A1 +.+ AK−1 = AK+1 +.+ AN−2 + AN−1。函数算法的基本原理很简单:检查向量中每个连续元素的和,并将其与其后元素的和进行比较,如果它们相等,则输出该元素的指数。虽然这听起来很简单(我认为是这样),但在现实中却很难实现。代码如下所示:

代码语言:javascript
复制
#include <iostream>
#include <vector>

using std::cin;
using std::cout;
using std::endl;

void EquilibriumPoint(std::vector<int> &A);
void VectorPrint(std::vector<int> &V);

void main()
{
    int input;
    std::vector<int> Vect1;
    cout << "Input the vector elements" << endl;
    while (cin >> input)
       Vect1.push_back(input);
    VectorPrint(Vect1);
    EquilibriumPoint(Vect1);
}

void EquilibriumPoint(std::vector<int> &A)
{

    for (int it = 0; it != A.size(); ++it)
    {
        int lowersum = 0;
        int uppersum = 0;
        for (int beg = 0; beg != it; ++beg) lowersum += A[beg];
        for (int end = it + 1; end != A.size(); ++end) uppersum += A[end];
        if (uppersum == lowersum) cout << it;
    }
}

void VectorPrint(std::vector<int> &V)
{
    for (int i = 0; i != V.size(); ++i)
        cout << V[i] << endl;
}

正如你所看到的,我加入了一个打印函数,这也是为了更好的度量。问题是程序似乎没有执行EquilibriumPoint函数。实现的逻辑肯定有问题,但我找不到。你们有什么建议吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-10-14 21:40:18

代码语言:javascript
复制
cin >> input 

总是为你返回真-所以IMHO你有一个无止境的循环。例如,您需要在某个时候停止收集元素。

代码语言:javascript
复制
int input = 1
while (input)
{
    cin >> input;
    Vect1.push_back(input);
}

将接受所有不是零的元素,当零到达时,它将结束向量并运行您的函数。

或者,您可以首先输入元素的数量(如果希望包括零),例如:

代码语言:javascript
复制
int count;
cin >> count
for (int i = 0; i < count; ++i)
{
  cin >> input;
  Vect1.push_back(input);
}

不过,我没有检查剩下的代码。一次一个问题。

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

https://stackoverflow.com/questions/26370735

复制
相关文章

相似问题

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