0

可能重复:
列表索引搜索

我必须在值相同的 int[] 中获取索引,因此我必须在 int[] 中获取相同值的所有索引 num。

前任。

int[] xx = {4,5,4,3,2}

我在用

Array.indexOf(xx, 4);

它会返回 0,但我想得到 0 和 2。

4

5 回答 5

5

怎么样

int[] xx = {4,5,4,3,2};

int search = 4;

var result = xx.Select((b, i) => b.Equals(search) ? i : -1).Where(i => i != -1);

在这里阅读我的原始答案。

于 2012-09-22T07:20:00.683 回答
1

我认为没有任何内置的单行代码(Nikhil 的方法与 LINQ 一样接近),但它很容易编写:

public static IEnumerable<int> FindAllIndexes(this IEnumerable<T> haystack,
                                              T needle) where T : IEquatable<T>
{
    int index = 0;
    foreach (var item in haystack)
    {
        if (item.Equals(needle))
        {
            yield return index;
        }
        index++;
    }
}

将其用作:

foreach (var index in array.FindAllIndexes(4))
{
    ...
}

如果您真的愿意,可以使用自定义比较器编写重载。

于 2012-09-22T07:21:41.553 回答
1
using System;
using System.Linq;

class Program
{
    static void Main(string[] args)
    {
        int[] xx = { 4, 5, 4, 3, 2 };
        int findValue = 4;
        var indexes = xx.Select((val, index) => new { Value = val, Index = index })
            .Where(x => x.Value == findValue)
            .Select(x => x.Index);
        foreach (var index in indexes)
            Console.WriteLine(index);
    }
}
于 2012-09-22T07:26:52.467 回答
0

您可以通过使用迭代器来做到这一点。

public IEnumerable<int>
GetIndexes(int[] xx, int toSearch )
{
  // Yield even numbers in the range. 
  for (int i= 0; i < xx.Length; i++)
  {
      if (xx[i] == toSearch)
      {
          yield return xx[i];
      }
  }
}
于 2012-09-22T07:22:58.947 回答
0

您可以简单地使用这样的方法(如果可以使用序列而不是数组):

static IEnumerable<int> AllIndexesOf(int[] xx, int value) {
    for (int i = 0; i < xx.Length; ++i) {
        if (xx[i] == 4) {
            yield return i;
        }
    }    
}
于 2012-09-22T07:24:16.197 回答