这道C语言问题错在哪里了
ProblemDescription输入n(n<100)个数,找出其中最小的数,将它与最前面的数交换后输出这些数。Input输入数据有多组,每组占一行,每行的开始是一个整...
Problem 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
------------------------------------------------------------
和结果都一样为什么总是wrong answer 杭电ACM的2016题
#include <iostream>
using namespace std;
#define max 99
int main(void)
{
int n, a[max];
while (scanf_s("%d", &n) != EOF&&n!=0)
{
for (int i = 0; i < n; i++)
scanf_s("%d", &a[i]);
for (int i = 0; i < n - 1; i++)
{
for (int j = i+1; j<n; j++)
{
if (a[i]>a[j])
{
int temp = a[i];
a[i] = a[j];
a[j] = temp;
}
}
}
for (int i = 0; i < n; i++)
{
if (i == n - 1)
cout << a[i] << endl;
else
cout << a[i] << " ";
}
}
return 0;
} 展开
输入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
------------------------------------------------------------
和结果都一样为什么总是wrong answer 杭电ACM的2016题
#include <iostream>
using namespace std;
#define max 99
int main(void)
{
int n, a[max];
while (scanf_s("%d", &n) != EOF&&n!=0)
{
for (int i = 0; i < n; i++)
scanf_s("%d", &a[i]);
for (int i = 0; i < n - 1; i++)
{
for (int j = i+1; j<n; j++)
{
if (a[i]>a[j])
{
int temp = a[i];
a[i] = a[j];
a[j] = temp;
}
}
}
for (int i = 0; i < n; i++)
{
if (i == n - 1)
cout << a[i] << endl;
else
cout << a[i] << " ";
}
}
return 0;
} 展开
3个回答
展开全部
#include<iostream>
using namespace std;
const int M=100;
int n;
int m[M];
int main()
{
int i,a,a1=0,temp;
while(cin>>n&&n>0)
{
for(i=0;i<n;i++)
{
cin>>m[i];
}
a=m[0]; a1=0; //记录数组的下标,每次都要归零
for(i=0;i<n;i++)
{
if(m[i]<a)
{
a=m[i];
a1=i;
}
}
temp=m[0];
m[0]=a;
m[a1]=temp;
for(i=0;i<n;i++)
{
if(i<n-1)
cout<<m[i]<<" ";
else
cout<<m[i]<<endl;
}
}
return 0;
}
寻找最小值即可,不需要排序
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
他只将最小数放到最前面 而不是做了冒泡
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询