一道编程题

[题目要求]

(1)自己给定一个集合(元数个数不得少于10个);

(2)让用户任一输入一个整数;

(3)根据用户输入的整数,移除集合中相应的元素(请根据示例找出元素移除的规律);

(4)运算结束后,集合中所有元素均被移除;

[示例]

集合元素为:A、B、C、D、E、F、G、H、I、J

用户输入的整数为:3

集合元素被移除的顺序为:C、D、E、F、G、H、I、J、A、B


我的程序为:

    class Program
    {
        static void Main(string[] args)
        {
            Program p = new Program();
            string[] name = { "A", "B", "C", "D", "E", "F", "G", "H", "I", "J" };  //自己给定的集合
            Console.Write("Please input a number:");
            int num = Convert.ToInt32(Console.ReadLine());    //用户输入的数字            
            ArrayList arr = new ArrayList(name);
            p.Handle(arr,num);  //处理方法
            Console.Write(arr.Count);   //输出运算结束后集合中元素的个数,正确结果应为0
            Console.ReadLine();
        }


        public void Handle(ArrayList arr,int num)
        {
            if (arr.Count >= num)   //若集合元素个数大小用户输入的整数
            {
                Console.WriteLine("当前移除的为:" + arr[num - 1]);
                arr.RemoveAt(num - 1);
                Handle(arr, num);   //递归调用                  
            }
            if(arr.Count>0 && arr.Count<num)    //若集合元素个数大小0且小于用户输入的整数
            {
                int mark = 1;   //累加标识
                int index = 0;  //移除元素下标标识
                while(arr.Count>0)
                {
                    if (mark == num)
                    {
                        Console.WriteLine("当前移除的为:" + arr[index]);
                        arr.RemoveAt(index);
                        mark = 1;
                        index = 0;
                    }
                    else
                    {
                        index++;
                        mark++;
                        if (index >= arr.Count) //如果移除元素下标标识index大于集合个数,即归0处理
                        {
                            index = 0;                            
                        }                       
                    }
                }
                return; //集合元素被全部移除,递归终止,整个运算处理结束,返回主函数
            }
        }
    }

   欢迎各位朋友贴出自己的想法:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值