ホームページ  >  記事  >  バックエンド開発  >  C# を使用して配列を k 回回転するにはどうすればよいですか?

C# を使用して配列を k 回回転するにはどうすればよいですか?

WBOY
WBOY転載
2023-09-12 14:49:09507ブラウズ

如何使用 C# 将数组旋转 k 次?

配列と数値 k が与えられた場合、問題は配列を k 回回転する必要があることを示しています。

指定された数値が 3 の場合、配列は 3 回回転する必要があります。

配列、開始位置、終了位置をパラメータとして受け取る関数 reverse を作成します。

  • 最初のステップでは、0 から配列の長さまで reverse メソッドが呼び出されます。

  • 2 番目のステップでは、リバース メソッドが 0 から k-1 まで呼び出されます。

  • 3 番目のステップでは、k 1 から配列の長さまで逆のメソッドが呼び出されます。

デモンストレーション

using System;
namespace ConsoleApplication{
   public class Arrays{
      public void ReverseArrayKTimes(int[] arr, int k){
         Reverse(arr, 0, arr.Length - 1);
         Reverse(arr, 0, k - 1);
         Reverse(arr, k, arr.Length - 1);
      }
      private void Reverse(int[] arr, int start, int end){
         while (start < end){
            int temp = arr[start];
            arr[start] = arr[end];
            arr[end] = temp;
            start++;
            end--;
         }
      }
   }
   class Program{
      static void Main(string[] args){
         Arrays a = new Arrays();
         int[] arr = { 9, 8, 7, 6, 5, 4, 3, 2, 1 };
         a.ReverseArrayKTimes(arr, 3);
         for (int i = 0; i < arr.Length; i++){
            Console.WriteLine(arr[i]);
         }
         Console.ReadLine();
      }
   }
}

出力

3 2 1 9 8 7 6 5 4

以上がC# を使用して配列を k 回回転するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はtutorialspoint.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。