先上代码···
#include <vector>
#include <algorithm>
#include<iostream>
using namespace std;
void solution (vector<int> & vecin )
{
int i=1;
vector<int>::iterator iter1=vecin.begin();
vector<int>::iterator iter2=vecin.begin();
vector<int>::iterator iter3=vecin.begin();
for(;iter1 !=vecin.end();)
{
while(*(iter1++) != i);
sort(iter3,iter1);
for(iter2=iter3;iter2!=iter1;iter2++)
if(*(iter2)==i) //如果不是按序输出,那么这个值应该还是后面
{
cout<<*(iter2)<< ' ';
i++;
}
else
break;
iter3=iter2;
cout<<endl;
}
}
也不知道对不对,反正测试【1-n】的乱序会正常输出,如果序列的最小值不是1 或者序列不连续这个都还不行,这是传说当中的鲁棒吗 ?还有单元测试是什么鬼?
题目的意思应该是序列要连续,不然怎么知道后面没有收到的序列值里还有最小的呢,把i从序列的最小值算起就解决了不是从1开始的问题。这是3个题中最简单的一道,但是还是在规定时间内没有码出来,一写代码就是各种错误,··crying!!!看来刷leetcode势在必行!
这机试做的,真是被虐成狗····前面的单选题我都不想说,小明你就不能消停点吗?又是去塞水塞拔水塞,又是匀速运动还跟汽车比,后面还带上小红轮流拿石头来秀恩爱···真是简直了···
还有前面两个码代码的题 ···阿里你不喜欢我就直说好不好
今天流的泪 都是当年让我上课睡觉进的水呀!不说了,我再去哭会儿