题目如下
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 n,b,c,d;
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:段错误,检查是否有数组越界,指针异常,访问到不应该访问的内存区域,求解答