问题描述
- Segmentation fault问题
- 题目如下
Description
输入n(n<100)个整数,找出其中最小的数,将它与最前面的数交换后输出这些数。Input
输入数据有多组,每组占一行,每行的开始是一个整数n,表示这个测试实例的数值的个数,跟着就是n个整数。n=0表示输入的结束,不做处理。Output
对于每组输入数据,输出交换后的数列,每组输出占一行。Sample Input
4 2 1 3 4
5 5 4 3 2 1
0
Sample Output
1 2 3 4
1 4 3 2 5我的代码
#include
#include
#include
#include
#include
using namespace std;int main()
{
int nbcd;
int number[100];
while (cin >> n)
{
if (n >= 0&&n {
if (n == 0)
break;
for (int a=0; a {
cin >> number[a];
if (a == 0)
{
b = number[a];
}
if (number[a] < b)
{
b = number[a];
c = a;
}
}
d = number[0];
number[0] = b;
number[c] = d;
for (int a = 0; a < n; a++)
{
cout << number[a]<<"" "";
}
cout << endl;
}
}
}在OJ上提示Segmentation fault:段错误,检查是否有数组越界,指针异常,访问到不应该访问的内存区域,求解答
解决方案
http://www.cnblogs.com/bucuo/archive/2012/06/05/2535554.html
解决方案二:
?
今天调试程序时遇到了一个问题,当我用GDB调试程序时出现了Segmentation fault,以前没有遇到过,最后查看资料,有点明白了。
??? 出现了Segmentation fault,基本上的原因是,非法的内存访问。
例如数组的越界,在循环操作时循环变量的控制问题,也有字符串拷贝时长度溢出,指针指向了非法的空间,还有......
答案就在这里:Segmentation fault 问题