堆栈 Stack类

Stack类的实现:

class CStack

    {
        private int p_index;
        private ArrayList list;
        public CStack()
        {
            list=new ArrayList();
            p_index =-1;
        }
        public int count
        {
            get{return list.Count;}
        }
        public void Push(object item)
        {
            list.Add(item);
            p_index++;
        }
        public object Pop()
        {
            object obj=list[p_index];
            list.RemoveAt(p_index);
            p_index--;
            return obj;
        }
        public void Clear()
        {
            list.Clear();
            p_index=-1;
        }
        public object Peek()
        {
             return list[p_index];
        }

    }


stack类的应用:十进制转换成其他进制:

class Program
    {
        static void Main(string[] args)
        {
            int num, baseNum;
            Console.Write("Enter a decimal number:");
            num = Convert.ToInt32(Console.ReadLine());
            Console.Write("Enter a base:");
            baseNum = Convert.ToInt32(Console.ReadLine());
            Console.Write(num + " converts to ");
            MulBase(num, baseNum);
            Console.WriteLine(" Base " + baseNum);
        }
        static void MulBase(int n, int b)
        {
            Stack Digits = new Stack();
            do 
            {
                Digits.Push(n % b);
                n = n / b;
            } while (n!=0);
            while (Digits.Count>0)
            {
                Console.Write(Digits.Pop());
                
            }
        }
    }





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值