📣 VIP通行证夏日特惠 限时立减$68
查看: 1498| 回复: 1
跳转到指定楼层
上一主题 下一主题
收起左侧

Stack with Two Queues (Or one queue)

全局:

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
本帖最后由 mamengduo 于 2013-6-23 12:44 编辑

这应该是一道老题了。我有些小疑问
通常的解法都要判断queue的size.

  1. public void Push(T val) { queLower.Enqueue(val); }
复制代码
  1. public  T Pop()
  2.     {

  3.         if (queLower.Count == 0 )
  4.         {
  5.             Console.Write("Stack is empty!");
  6.             return default(T);

  7.          }
  8.         if (queLower.Count > 0)
  9.         {
  10.             for (int i = 0; i < queLower.Count - 1;i++ )
  11.             {
  12.                 queLower.Enqueue(queLower.Dequeue ());
  13.            }
  14.                     }

  15.         return queLower.Dequeue();

  16.     }
复制代码

如何不用queue.count或queue.isempty()来实现? (该疑问源自这个帖子:http://www.careercup.com/question?id=3185682 有个人说他在微软技术面时候不让使用queue.count)
引用自该帖子:
I got the same question during a Microsoft technical screen and the guy is like I don't want you to use a count(q.Count) on the queue! Nor to check for queue.isEmtpy(). So my solution relied on catching the exception and handling it and I had a slight bug in my implementation which I discovered but wasn't able to fix. Guess what.. reject! We think the world is sane and we are programming for objects/collection and can count them, apparently we can't :)

上一篇:分享我2年的程序员经历和求教如何提高自己的编程能力
下一篇:发个福利吧,CareerCup,5th Edition的 高清扫描版118M,积分要求降低了。快来下
🔗
淡雪初晴 2013-6-24 01:26:41 | 只看该作者
全局:
数组队列。数组size为n,但只保存n-1个元素。这样空head==(rear+1)%n,满head==(rear+2)%n
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表