可能重复:
List Index Search
我必须在int []中得到索引,其中value将是相同的,因此我必须得到int []中相同值的所有索引号。
离。
int[] xx = {4,5,4,3,2}
我正在使用
Array.indexOf(xx, 4);
它将返回0但我想得到0和2。
答案 0 :(得分: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);
阅读我的原始答案here。
答案 1 :(得分: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))
{
...
}
如果您真的想要,可以使用自定义比较器编写重载。
答案 2 :(得分: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);
}
}
答案 3 :(得分: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];
}
}
}
答案 4 :(得分:0)
你可以简单地使用这样的方法(如果没有序列而不是数组):
static IEnumerable<int> AllIndexesOf(int[] xx, int value) {
for (int i = 0; i < xx.Length; ++i) {
if (xx[i] == 4) {
yield return i;
}
}
}