[题目要求]
(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; //集合元素被全部移除,递归终止,整个运算处理结束,返回主函数
}
}
}
欢迎各位朋友贴出自己的想法: