2016-12-28 110 views
-5

在输入第一个值并尝试继续时,我无法解决为什么我在屏幕截图中出现错误。C++“Program.exe已停止工作”

该错误仅在下面的代码中发生。

任何帮助,将不胜感激!

Error screenshot

//Darbas40 
#include <io.h> 
#include <iostream> 
#include <iomanip> 
#include <cmath> 

using namespace std; 

int main() 

{ 

int n, 
    u, 
    m, 
    ms, 
    v, 
    vs, 
    i; 
double vidvaikinu, 
     vidmerginu; 

n = 7; m = 0; v = 0; ms = 0; vs = 0; 

for (i = 1; i <= n; i++) 
{ 
    wcout << "Iveskite mokiniu ugius: "; cin >> u; 
    if (u > 0) 
    { 
     m++; 
     ms = ms + u; 
    } 
    else if (u < 0) 
    { 
     v++; 
     vs = vs + u; 
    } 
    vidmerginu = ms/m; 
    vidvaikinu = fabs(vs/v); 
    } 

    wcout << " " << endl; 
    wcout << "vidvaikinu = " << vidvaikinu << ", vidmerginu = " << vidmerginu << "." << endl; 

return 0; 
} 
+0

欢迎来到Stack Overflow。请花些时间阅读[The Tour](http://stackoverflow.com/tour),并参阅[帮助中心](http://stackoverflow.com/help/asking)中的资料,了解您可以在这里问。 –

+1

'v'造成零除。这就是为什么你应该声明和初始化*每行一个变量*,除了由于格式化和样式不佳,你的代码非常难以阅读。 – CoryKramer

+5

解决这些问题的正确工具是您的调试器。在*堆栈溢出问题之前,您应该逐行执行您的代码。如需更多帮助,请阅读[如何调试小程序(由Eric Lippert撰写)](https://ericlippert.com/2014/03/05/how-to-debug-small-programs/)。至少,您应该\编辑您的问题,以包含一个[最小,完整和可验证](http://stackoverflow.com/help/mcve)示例,该示例再现了您的问题,以及您在调试器。 –

回答

1

你会零错误如果u <= 0中得到鸿沟:

vidmerginu = ms/m; 

因为m设置为0,而不是增加。

且通过零误差的鸿沟,如果u >= 0在:

vidvaikinu = fabs(vs/v); 

因为v设置为0,而不是增加。