deque中使用迭代器进行运算的函数都默认以.end()为结束,而实际上.end()所返回的是最后一个元素的下一个位置,所以进行数据比较时,应对其-1才是对应的最后一个数据,而函数中则是直接使用.end()即可。
reverse函数用于翻转接受的起始位置和终点位置的元素,max_element函数用于找出接收的起始位置和终点位置之间的最大元素。头文件都为<algorithm>。
#include<iostream> #include<stack> #include<queue> #include<string> #include<sstream> #include<iterator> #include<algorithm> using namespace std; const int maxn=210; int main() { for(string input; getline(cin,input); cout<<'0'<<endl) { cout<<input<<endl; istringstream iss(input); deque <int > flap; for(int temp; iss>>temp; flap.push_front(temp));///push_front()函数用于从头部插入元素,因而flap中存储的即是按题目中输入顺序的逆序存储的 for(deque <int >:: iterator i=flap.begin(); i!=flap.end(); ++i) { deque<int>::iterator iMax = max_element(i,flap.end()); if(iMax!=i)///当顶端的元素不是最大元素时,就要进行翻转 { if(iMax!=flap.end()-1)///如果最大的不在最底部,就要先翻转,使最大的在底部,才能使下一次翻转时最大的在顶部 { reverse(iMax,flap.end()); cout<<distance(flap.begin(),iMax)+1<<' ';///输出最大的元素与开始元素的距离,即是我们翻转了几次 } reverse(i,flap.end()); cout<<distance(flap.begin(),i)+1<<' ';///.begin()指向的一直都是第一个元素,虽然reverse了,但是.begin()指向的还是一开始的第一个元素,由于我们是一步一步进行翻转,所以距离一开始的元素的距离+1就是我们翻转的次数。 } } } return 0; }
浙公网安备 33010602011771号