网页资讯视频图片知道文库贴吧地图采购
进入贴吧全吧搜索

 
 
 
日一二三四五六
       
       
       
       
       
       

签到排名:今日本吧第个签到,

本吧因你更精彩,明天继续来努力!

本吧签到人数:0

一键签到
成为超级会员,使用一键签到
一键签到
本月漏签0次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行补签。
连续签到:天  累计签到:天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
06月11日漏签0天
c++吧 关注:618,778贴子:2,111,443
  • 看贴

  • 图片

  • 吧主推荐

  • 游戏

  • 1回复贴,共1页
<<返回c++吧
>0< 加载中...

【菜鸟提问】 在bestcoder上一道简单的题,一直提示错误,求帮忙

  • 取消只看楼主
  • 收藏

  • 回复
  • い文超
  • ||
    5
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
Description
输入n(n<100)个数,找出其中最小的数,将它与最前面的数交换后输出这些数。
Input
输入数据有多组,每组占一行,每行的开始是一个整数n,表示这个测试实例的数值的个数,跟着就是n个整数。n=0表示输入的结束,不做处理
Output
对于每组输入数据,输出交换后的数列,每组输出占一行
Sample Inpu
4 2 1 3 4
5 5 4 3 2 1
0
Sample Outpu
1 2 3 4
1 4 3 2 5
我的答案:(花了我一个多小时,头都有点迷糊了,就是找不出错误...试了很多例子,都觉得输出没问题,求大神帮帮忙。)
#include <iostream>
#include <vector>
using namespace std;
void swapVec(vector<int> &vec, int i, int j)
{
if(i == j)
return;
int num = vec[i];
vec[i] = vec[j];
vec[j] = num;
}
int main()
{
int n;
vector<vector<int> > res;
while(cin >> n)
{
if(n > 0) //判断是否该结束
{
vector<int> r; //存储每一遍结果
int min = -1; //存储最小值
int pos = 0; //存储最小值对应位置
for(int i = 0; i < n; i++)
{
int x;
cin >> x;
if(i == 0)
{
min = x;
}
else if(min > x)
{
min = x;
pos = i;
}
r.push_back(x);
}
swapVec(r,0,pos); //交换最前面的数和最小值
res.push_back(r); //保存该次结果
}
else
{
for(int i = 0; i < res.size(); i++) //结果展示
{
for(int k = 0; k < res[i].size(); k++)
cout << res[i][k] << ends;
cout << endl;
}
break;
}
}
return 0;
}


  • い文超
  • ||
    5
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
有大神帮忙看看吗? 题不难..就是不对... 纠结一下午了...


登录百度账号

扫二维码下载贴吧客户端

下载贴吧APP
看高清直播、视频!
  • 贴吧页面意见反馈
  • 违规贴吧举报反馈通道
  • 贴吧违规信息处理公示
  • 1回复贴,共1页
<<返回c++吧
分享到:
©2025 Baidu贴吧协议|隐私政策|吧主制度|意见反馈|网络谣言警示