-4

我已经为“反转数组并且反转后不显示重复元素”编写了这个程序,但它只打印到倒数第二个元素:

int[] a = new int[] { 1, 2, 3, 4, 5, 5, 6, 7, 8, 9, 10 };

for (int i = 0; i < a.Length / 2; i++)
{
    int tmp = a[i];//Getting First/current element
    a[i] = a[a.Length - i - 1];//Getting last Element and assigning to first/current                
    a[a.Length - i - 1] = tmp;
}

int j=0;
for(int i=0;i< a.Length;i++)
{
    j=i+1;
    if(j < a.Length)
    {
        if (a[i] != a[j])
            Console.WriteLine(a[i]);
    }
    j++;
}

我究竟做错了什么?

4

3 回答 3

11

你做错的是没有使用 LINQ:

foreach (int i in a.Reverse().Distinct())
{
    Console.WriteLine(i);
}

但是,您似乎想手动执行此操作,这是一个实现:

IEnumerable<T> Reverse<T>(this IList<T> arr)
{
    if (arr == null) throw new ArgumentNullException();
    for(int i = arr.Count - 1; i > 0; i--) yield return arr[i];
}
IEnumerable<T> Distinct<T>(this IEnumerable<T> list)
{
    Hashset<T> tmpHash = new Hashset<T>();
    foreach (T item in list) tmpHash.Add(item);
    return tmpHash;
}
//your method is now simple as:
a.Reverse().Distinct(); //hey, looks like LINQ but I've implemented it myself.
于 2013-06-30T19:54:39.613 回答
6

尝试这个 :

        var arr = new int[] {1,2,4,5,6,4,5};
        var tmp = arr.Reverse().Distinct();

希望这有帮助。

于 2013-06-30T19:55:52.207 回答
0

如果i = a.Length-1 j = a.Length是这样j >= a.Length,最后一个i Console.WriteLine(a[i]);不叫

于 2013-06-30T19:59:17.353 回答