C# 程序检查二进制数中有无连续 K 个 1


要检查二进制数中有无连续的 1,需要检查 0 和 1。

首先,为 0 和 1 设置一个布尔数组,即 false 和 true -

bool []myArr = {false, true, false, false, false, true, true, true};

对于 0,将计数设置为 0 -

if (myArr[i] == false)
   count = 0;

对于 1,增加计数并设置结果。Max() 方法返回两个数中较大的一个 -

count++;
res = Math.Max(res, count);

示例

以下是检查二进制数中有无连续 K 个 1 的示例 -

演示

using System;
class MyApplication {
   static int count(bool []myArr, int num) {
      int myCount = 0, res = 0;
      for (int i = 0; i < num; i++) {
         if (myArr[i] == false)
            myCount = 0;
         else {
            myCount++;
            res = Math.Max(res, myCount);
         }
      }
      return res;
   }
   public static void Main() {
      bool []myArr = {false, true, false, false, false, true, true, true};
      int num = myArr.Length;
      Console.Write("Consecutive 1's = "+count(myArr, num));
   }
}

输出

Consecutive 1's = 3

更新于: 19-Jun-2020

238 次浏览

职业进阶

通过完成认证课程获得认证

开始
广告
© . All rights reserved.