阿里巴巴2015校园招聘算法题

1190阅读 0评论2015-04-02 B_C_1024
分类:C/C++

题目:分布式系统中的RPC请求经常出现乱序情况。
写一个算法讲一个乱序的序列保序输出。例如,假设起始序号是1,对于(1,2,5,8,10,4,3,6,9,7),则输出是
1
2
3 4 5
6
7 8 9 10
上述例子中,3到来的时候,发现4,5已经存在了,因此将(3,4,5)输出。
  1. #include
  2. #include
  3. #include
  4. #include
  5. using namespace std;
  6. class Solution{
  7. public:
  8.     static void printInOrder(vector<int> & num)
  9.     {
  10.         unordered_multiset<int> tmp ;
  11.         int needNum = 1;
  12.         for (auto iter = num.begin(); iter != num.end(); iter++)
  13.         {
  14.             if (*iter != needNum)
  15.             {
  16.                 
  17.                 tmp.insert(*iter);
  18.                 continue;
  19.             }
  20.             tmp.insert(*iter);
  21.             while (true)
  22.             {
  23.                     auto tmpiter = tmp.find(needNum);
  24.                     if (tmpiter == tmp.end())
  25.                         break;
  26.                     else
  27.                     {
  28.                         cout << *tmpiter<<" ";
  29.                         needNum = *tmpiter+1;
  30.                         tmp.erase(tmpiter);
  31.                     }
  32.             }
  33.             cout << endl;
  34.         }
  35.     }
  36. };

  37. int
  38. main()
  39. {
  40.     vector<int> num = {11,10,9,8,7,6,5,4,3,2,1 };
  41.     //vector<int> num;
  42.     Solution::printInOrder(num);
  43.     system("pause");
  44.     return 0;
  45. }


上一篇:从select的一个死循环谈epoll的ET模式
下一篇:C++数组与多态