私はC#で作業しており、並べ替えられたList<T>
of structs。 List
を反復処理しようとしています。反復ごとに、リストの次のメンバーにアクセスしたいと思います。これを行う方法はありますか?
擬似コードの例:
foreach (Member member in List)
{
Compare(member, member.next);
}
できません。代わりにforを使用します
for(int i=0; i<list.Count-1; i++)
Compare(list[i], list[i+1]);
代わりに、以前の値を保持することもできます。
T prev = default(T);
bool first = true;
foreach(T item in list) {
if(first) {
first = false;
} else {
Compare(prev, item);
}
prev = item;
}
もしその傾向があるなら、おそらくこれのための拡張メソッドも書くことができるでしょう...
public static void ForEachNext<T>(this IList<T> collection, Action<T, T> func)
{
for (int i = 0; i < collection.Count - 1; i++)
func(collection[i], collection[i + 1]);
}
使用法:
List<int> numList = new List<int> { 1, 3, 5, 7, 9, 11, 13, 15 };
numList.ForEachNext((first, second) =>
{
Console.WriteLine(string.Format("{0}, {1}", first, second));
});
[〜#〜] linq [〜#〜] ここにあなたの友達かもしれません。このアプローチは、IEList <T>コレクションだけでなく、IEnumerable <T>でも機能します。これは、コレクションが終了しない場合や、オンザフライで計算される場合に非常に便利です。
class Program {
static void Main(string[] args) {
var list = new List<Int32> { 1, 2, 3, 4, 5 };
foreach (var comparison in list.Zip(list.Skip(1), Compare)) {
Console.WriteLine(comparison);
}
Console.ReadKey();
}
static Int32 Compare(Int32 first, Int32 second) {
return first - second;
}
}
インデックス付きの通常のforループを使用して、list [i]とlist [i + 1]を比較します。 (ただし、最後から2番目のインデックスまでループすることを確認してください。)
または、本当にforeachを使用したい場合は、以前のメンバーへのメンバー参照を保持し、次回を確認できます。しかし、私はそれをお勧めしません。
XmlNode root = xdoc.DocumentElement;
XmlNodeList nodeList = root.SelectNodes("descendant::create-backup-sets/new-file-system-backup-set");
for (int j = 0; j < nodeList.Count; j++ )
{
for (int i = 0; i <= nodeList.Item(j).ChildNodes.Count - 1; i++)
{
if (nodeList.Item(j).ChildNodes[i].Name == "basic-set-info")
{
if (nodeList.Item(j).ChildNodes[i].Attributes["name"].Value != null)
{
// retrieve backup name
_bName = nodeList.Item(j).ChildNodes[i].Attributes["name"].Value.ToString();
}
}