📌  相关文章
📜  找到最后一个能够翻转二进制字符串中的字符的玩家

📅  最后修改于: 2021-04-18 02:30:53             🧑  作者: Mango

给定长度为N的二进制字符串S ,任务是如果两个玩家AB按照以下规则最佳玩法,则找到游戏的获胜者:

  • 玩家A总是开始游戏。
  • 在玩家的第一回合中,他可以移动到由‘0’组成的任何索引(基于1的索引)并将其设置为‘1’
  • 在随后的回合中,如果任何玩家的下标为i ,则他可以移动到它的相邻指数之一(如果其中包含0) ,并在移动后将其转换为“ 1”
  • 如果在转牌过程中任何玩家无法移动到任何位置,则该玩家将输掉比赛。

任务是找到游戏的获胜者。

例子:

方法:这个想法是将给定数组arr []中所有仅包含0的子字符串的长度存储在另一个数组中,例如V [] 。现在,出现以下情况:

  1. 如果V的大小为0 在这种情况下,数组不包含任何0 。因此,玩家A不能采取任何行动并输掉了比赛。因此,请打印Player B。
  2. 如果V的大小为1 在这种情况下,存在1个仅由0组成的子串,例如长度L。如果L的值是奇数,则玩家A赢得游戏。否则,玩家B赢得比赛。
  3. 在所有其他情况下:将最大和第二最大连续段的长度0 s分别存储在第一段第二段中。如果且仅当first的值是奇数且(first + 1)/ 2> second时,玩家A才能赢得比赛。否则,玩家B赢得比赛。

下面是上述方法的实现:

C++
// C++ program for the above approach
#include 
using namespace std;
 
// Function to check if player A wins
// the game or not
void findWinner(string a, int n)
{
    // Stores size of the groups of 0s
    vector v;
 
    // Stores size of the group of 0s
    int c = 0;
 
    // Traverse the array
    for (int i = 0; i < n; i++) {
 
        // Increment c by 1 if a[i] is 0
        if (a[i] == '0') {
            c++;
        }
 
        // Otherwise, push the size
        // in array and reset c to 0
        else {
            if (c != 0)
                v.push_back(c);
            c = 0;
        }
    }
    if (c != 0)
        v.push_back(c);
 
    // If there is no substring of
    // odd length consisting only of 0s
    if (v.size() == 0) {
        cout << "Player B";
        return;
    }
 
    // If there is only 1 substring of
    // odd length consisting only of 0s
    if (v.size() == 1) {
        if (v[0] & 1)
            cout << "Player A";
 
        // Otherwise
        else
            cout << "Player B";
        return;
    }
 
    // Stores the size of the largest
    // and second largest substrings of 0s
    int first = INT_MIN;
    int second = INT_MIN;
 
    // Traverse the array v[]
    for (int i = 0; i < v.size(); i++) {
 
        // If current element is greater
        // than first, then update both
        // first and second
        if (a[i] > first) {
            second = first;
            first = a[i];
        }
 
        // If arr[i] is in between
        // first and second, then
        // update second
        else if (a[i] > second
                 && a[i] != first)
            second = a[i];
    }
 
    // If the condition is satisfied
    if ((first & 1)
        && (first + 1) / 2 > second)
        cout << "Player A";
    else
        cout << "Player B";
}
 
// Driver Code
int main()
{
    string S = "1100011";
    int N = S.length();
    findWinner(S, N);
 
    return 0;
}


Java
// Java program for the above approach
import java.util.*;
public class GFG
{
 
  // Function to check if player A wins
  // the game or not
  static void findWinner(String a, int n)
  {
 
    // Stores size of the groups of 0s
    Vector v = new Vector(); 
 
    // Stores size of the group of 0s
    int c = 0;
 
    // Traverse the array
    for (int i = 0; i < n; i++)
    {
 
      // Increment c by 1 if a[i] is 0
      if (a.charAt(i) == '0')
      {
        c++;
      }
 
      // Otherwise, push the size
      // in array and reset c to 0
      else
      {
        if (c != 0)
          v.add(c);
        c = 0;
      }
    }
    if (c != 0)
      v.add(c);
 
    // If there is no substring of
    // odd length consisting only of 0s
    if (v.size() == 0)
    {
      System.out.print("Player B");
      return;
    }
 
    // If there is only 1 substring of
    // odd length consisting only of 0s
    if (v.size() == 1)
    {
      if ((v.get(0) & 1) != 0)
        System.out.print("Player A");
 
      // Otherwise
      else
        System.out.print("Player B");
      return;
    }
 
    // Stores the size of the largest
    // and second largest substrings of 0s
    int first = Integer.MIN_VALUE;
    int second = Integer.MIN_VALUE;
 
    // Traverse the array v[]
    for (int i = 0; i < v.size(); i++)
    {
 
      // If current element is greater
      // than first, then update both
      // first and second
      if (a.charAt(i) > first) {
        second = first;
        first = a.charAt(i);
      }
 
      // If arr[i] is in between
      // first and second, then
      // update second
      else if (a.charAt(i) > second
               && a.charAt(i) != first)
        second = a.charAt(i);
    }
 
    // If the condition is satisfied
    if ((first & 1) != 0
        && (first + 1) / 2 > second)
      System.out.print("Player A");
    else
      System.out.print("Player B");
  }
 
  // Driver code
  public static void main(String[] args)
  {
    String S = "1100011";
    int N = S.length();
    findWinner(S, N);
  }
}
 
// This code is contributed by divyeshrabadiya07.


Python3
# Python3 program for the above approach
import sys
 
# Function to check if player A wins
# the game or not
def findWinner(a, n) :
 
    # Stores size of the groups of 0s
    v = []
 
    # Stores size of the group of 0s
    c = 0
 
    # Traverse the array
    for i in range(0, n) :
 
        # Increment c by 1 if a[i] is 0
        if (a[i] == '0') :
            c += 1
 
        # Otherwise, push the size
        # in array and reset c to 0
        else :
            if (c != 0) :
                v.append(c)
            c = 0
     
    if (c != 0) :
        v.append(c)
 
    # If there is no substring of
    # odd length consisting only of 0s
    if (len(v) == 0) :
        print("Player B", end = "")
        return
 
    # If there is only 1 substring of
    # odd length consisting only of 0s
    if (len(v) == 1) :
        if ((v[0] & 1) != 0) :
            print("Player A", end = "")
 
        # Otherwise
        else :
            print("Player B", end = "")
        return
 
    # Stores the size of the largest
    # and second largest substrings of 0s
    first = sys.minsize
    second = sys.minsize
 
    # Traverse the array v[]
    for i in range(len(v)) :
 
        # If current element is greater
        # than first, then update both
        # first and second
        if (a[i] > first) :
            second = first
            first = a[i]
 
        # If arr[i] is in between
        # first and second, then
        # update second
        elif (a[i] > second and a[i] != first) :
            second = a[i]
 
    # If the condition is satisfied
    if (((first & 1) != 0) and (first + 1) // 2 > second) :
        print("Player A", end = "")
    else :
        print("Player B", end = "")
 
S = "1100011"
N = len(S)
findWinner(S, N)
 
# This code is contributed by divyesh072019.


C#
// C# program to implement
// the above approach
using System;
using System.Collections.Generic;
using System.Linq;
 
class GFG{
 
  // Function to check if player A wins
  // the game or not
  static void findWinner(string a, int n)
  {
 
    // Stores size of the groups of 0s
    List v = new List(); 
 
    // Stores size of the group of 0s
    int c = 0;
 
    // Traverse the array
    for (int i = 0; i < n; i++)
    {
 
      // Increment c by 1 if a[i] is 0
      if (a[i] == '0')
      {
        c++;
      }
 
      // Otherwise, push the size
      // in array and reset c to 0
      else
      {
        if (c != 0)
          v.Add(c);
        c = 0;
      }
    }
    if (c != 0)
      v.Add(c);
 
    // If there is no substring of
    // odd length consisting only of 0s
    if (v.Count == 0)
    {
      Console.Write("Player B");
      return;
    }
 
    // If there is only 1 substring of
    // odd length consisting only of 0s
    if (v.Count == 1)
    {
      if ((v[0] & 1) != 0)
        Console.Write("Player A");
 
      // Otherwise
      else
        Console.Write("Player B");
      return;
    }
 
    // Stores the size of the largest
    // and second largest substrings of 0s
    int first = Int32.MinValue;
    int second = Int32.MinValue;
 
    // Traverse the array v[]
    for (int i = 0; i < v.Count; i++)
    {
 
      // If current element is greater
      // than first, then update both
      // first and second
      if (a[i] > first) {
        second = first;
        first = a[i];
      }
 
      // If arr[i] is in between
      // first and second, then
      // update second
      else if (a[i] > second
               && a[i] != first)
        second = a[i];
    }
 
    // If the condition is satisfied
    if ((first & 1) != 0
        && (first + 1) / 2 > second)
      Console.Write("Player A");
    else
      Console.Write("Player B");
  }
 
 
// Driver Code
public static void Main(String[] args)
{
    string S = "1100011";
    int N = S.Length;
    findWinner(S, N);
}
}
 
// This code is contributed by splevel62.


输出:
Player A

时间复杂度: O(N)
辅助空间: O(N)