用C#实现从标准输入中输入两组整数(每行不超过20个整数,每组整数中元素不重复),合并两组整数,去掉在两组整数中都出现的整数,并按从大到小顺序排序输出(即两组整数集“异或”)。
该代码为最基础的方式来实现代码,因为是初学者所使用的程序较为简单繁琐,欢迎大佬提供更多建议或批评指正。
代码如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
//从标准输入中输入两组整数(每行不超过20个整数,每组整数中元素不重复),合并两组整数,去掉在两组整数中都出现的整数,
//并按从大到小顺序排序输出(即两组整数集“异或”)。
namespace C#
{
internal class Program
{
static void Main(string[] args)
{
Console.Write("请输入两组整数集(用空格分隔每组整数,行末以回车换行):");
try
{
//1、从键盘输入n(n<=20)个用空格隔开的整数,请输出它们的和
//第一步:获得输入的数字字符串
string str1 = Console.ReadLine();
string str2 = Console.ReadLine();
Console.WriteLine("第一组整数为"+str1);
Console.WriteLine("第二组整数为"+str2);
string str = str1 + str2;
//第二步: 使用分隔符拆分成字符数组
string[] strArray1 = str1.Split(' '); // 用 将str拆分成一个数组
string[] strArray2 = str2.Split(' ');
//string[] strArray3 = strArray1.Intersect(strArray2).ToArray();//该数组中包含重复的数字
var strArray = strArray1.Union(strArray2).Except(strArray1.Intersect(strArray2)).ToArray();
//第三步: 类型转换
int[] intArray = new int[strArray.Length];
if (strArray.Length <= 20 && strArray.Length > 0)
{
for (int i = 0; i < strArray.Length; i++)
{
intArray[i] = int.Parse(strArray[i]);
}
//数组的排序
//升序排列
Array.Sort(intArray);
Array.Reverse(intArray);//反转
Console.Write("合并后按从大到小的顺序排列得到的整数集为");
for (int i = 0; i < intArray.Length; i++)
{
Console.Write(intArray[i] + " ");
}
}
}
catch (Exception err)
{
Console.WriteLine("出现异常情况:" + err.Message);//err.Message可以显示出异常的原因
}
Console.ReadLine();
}
}
}
运行样例如下: