搜索
首页后端开发C++在进行所有可能的K次操作后,给定二进制字符串中设置位计数的平均值

在进行所有可能的K次操作后,给定二进制字符串中设置位计数的平均值

在这个问题中,我们需要对给定的字符串进行所有选择的 K 次运算后,求出设置位计数的平均值。

可以使用暴力方法来解决问题,但我们将使用概率原理来克服暴力方法的时间复杂度。

问题陈述 - 我们给定一个整数 N,包含 K 个正整数的数组 arr[],以及一个长度为 N 的二进制字符串,其中只包含设置位。我们需要找出在执行所有可能的 K 次操作后,设置位计数的平均值。在第 i 次操作中,我们可以翻转给定字符串中的任何 arr[i] 位。

示例

输入– N = 2, arr[] = {1, 2}

输出– 1

说明 – 初始二进制字符串为 11。

  • 第一步,我们可以翻转第一个字符,字符串将是01。

    • 在第二次操作中,我们需要翻转任意两个位。所以字符串将变为10。

  • 第二个选择可以从翻转第一步中的第二个字符开始,字符串将为 10。

    • 在当前操作的第二步中,我们需要翻转任意2个位,字符串可以是01。

所以,我们有两个选择,最终的字符串可以是01或者10。

总选择 = 2,最终字符串中的总设置位 = 2,ans = 2/2 = 1。

输入– N = 3, arr[] = {2, 2}

输出– 1.6667

Explanation – 我们有一个初始字符串是111。

  • 在第一个操作中,我们可以翻转任意 2 个字符。因此,字符串可以是 001、100、010。

  • 在第二个操作中,我们可以翻转第一个操作得到的结果字符串中的2个位。

    • 当我们翻转001的任意两个位时,我们得到111、010和100。

    • 当我们翻转 100 的任意 2 位时,我们可以得到 010、111 和 001。

    • 当我们翻转010的任意两个位时,我们可以得到100、001和111。

所以,在上一次操作中,我们得到了总共9个不同的字符串。

9个字符串中的总设置位数=15,总操作次数=9,答案=15/9=1.6667

方法一

在这里,我们将使用概率原理来解决这个问题。假设在执行了 i-1 次操作后,设置位的平均值为 p,非设置位的平均值为 q。我们需要计算第 i 次操作中设置位和非设置位的平均值。

所以,p的更新值可以是p + 新设置位的平均数 - 新关闭位的平均数。

算法

  • 将P初始化为N,因为我们最初有N个设置位,将Q初始化为0,因为我们最初有0个设置位。

  • 遍历操作数组。

  • 使用 P 和 Q 值初始化 prev_p 和 prev_q。

  • 使用prev_p - prev_p * arr[i] / N + prev_q * arr[i] / N更新P值,这将平均将反转的位添加到设置的位中,并将平均设置的位反转为未设置的位

  • 更新 Q 值。

  • 返回 P 值。

Example

的中文翻译为:

示例

#include <bits/stdc++.h>
using namespace std;

double getAverageBits(int len, int K, int array[]) {
   // to store the average '1's in the binary string
   double P = len;
   // to store the average '0's in the binary string
   double Q = 0;
   // Traverse the array array[]
   for (int i = 0; i < K; i++) {
      // Initialize the prev_p and prev_q with P and Q, which we got from the previous iteration
      double prev_p = P, prev_q = Q;
      // Update the average '1's
      P = prev_p - prev_p * array[i] / len + prev_q * array[i] / len;
      // Update the average '0's
      Q = prev_q - prev_q * array[i] / len + prev_p * array[i] / len;
   }
   return P;
}
int main() {
   int N = 2;
   int array[] = {1};
   int K = sizeof(array) / sizeof(array[0]);
   cout << "The average number of set bits after performing the operations is " << getAverageBits(N, K, array);
   return 0;
}

输出

The average number of set bits after performing the operations is 1

时间复杂度 - O(K),其中K是数组的长度。

空间复杂度 - O(1),因为我们没有使用任何额外的空间。

在本教程中,我们学习了在执行 K 操作的所有可能选择后找到平均设置位。在单选中,我们需要执行数组中给出的所有操作。

以上是在进行所有可能的K次操作后,给定二进制字符串中设置位计数的平均值的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:tutorialspoint。如有侵权,请联系admin@php.cn删除
使用C++编写,找到以1开头的二进制字符串的唯一排列数量使用C++编写,找到以1开头的二进制字符串的唯一排列数量Sep 05, 2023 am 09:01 AM

在给定的问题中,我们得到一个由0和1组成的字符串;我们需要找到以1开头的所有排列的总数。由于答案可能是一个巨大的数字,所以我们将其取模1000000007后输出。Input:str="10101001001"Output:210Input:str="101110011"Output:56我们将通过应用一些组合数学和建立一些公式来解决这个问题。解决方案的方法在这个方法中,我们将计算0和1的数量。现在假设n是我们字符串中出现的1的数量,m是我们字符串中出现的0

最长非递增子序列在一个二进制字符串中最长非递增子序列在一个二进制字符串中Sep 07, 2023 pm 11:13 PM

在这个问题中,我们需要找到给定字符串的最长非递增子序列。非递增的意思是字符要么相同,要么按降序排列。由于二进制字符串仅包含“0”和“1”,因此生成的字符串应以“1”开头并以“0”结尾,或者以“0”或“1”开头和结尾。为了解决这个问题,我们将统计字符串每个位置的前缀“1”和后缀“0”,并找到前缀“1”和后缀“0”的最大和。问题陈述-我们给出了二进制字符串str。我们需要从给定的字符串中找到最长的非递增子序列。示例Input–str="010100"Output–4说明最长的非递

在PHP中,pack()函数的作用是将数据转换为二进制字符串在PHP中,pack()函数的作用是将数据转换为二进制字符串Aug 31, 2023 pm 02:05 PM

pack()函数将数据打包到二进制字符串中。语法pack(format,args)参数格式-要使用的格式。以下是可能的值-a-NUL填充字符串A-空格填充字符串h-十六进制字符串,低半字节在前H-十六进制字符串,高半字节在前c-带符号字符C-无符号字符s-带符号短字符(始终为16位,机器字节顺序)S-无符号短整型(始终为16位,机器字节顺序)n-无符号短整型(始终为16位,大端字节顺序)v-无符号短整型(始终为16位,小端字节顺序)i-有符号整数(取决于机器的大小和字节顺序)I-无符号整数(取决

检查一个字符串是否可以通过交换二进制字符串中具有不相等字符的索引处的字符对来形成回文字符串检查一个字符串是否可以通过交换二进制字符串中具有不相等字符的索引处的字符对来形成回文字符串Sep 02, 2023 pm 08:09 PM

问题陈述我们有一个字符串str和一个二进制字符串B。两个字符串的长度都等于N。我们需要检查是否可以通过在字符串B中包含不相等字符的任意索引对上多次交换其字符,使字符串str成为回文字符串。示例示例输入str=‘AAS’B=‘101’输出‘YES’Explanation的中文翻译为:解释我们可以交换str[1]和str[2],因为B[1]和B[2]不相等。最终的字符串可以是'ASA'。输入str=‘AASS’B=‘1111’输出‘No’Explanation的中文翻译为:解释我们无法使字符串回文,

通过从给定的二进制字符串中选择相等长度的子字符串,最大化给定函数通过从给定的二进制字符串中选择相等长度的子字符串,最大化给定函数Aug 28, 2023 am 09:49 AM

给定两个相同长度的二进制字符串str1和str2,我们必须通过从给定的相同长度的字符串中选择子字符串来最大化给定的函数值。给定的函数是这样的-fun(str1,str2)=(len(子字符串))/(2^xor(sub1,sub2))。这里,len(substring)是第一个子字符串的长度,而xor(sub1,sub2)是给定子字符串的异或,因为它们是二进制字符串,所以这是可能的。示例Input1:stringstr1=10110&stringstr2=11101Output:3说明我们

计算长度为N的二进制字符串,它们是子字符串的重复拼接计算长度为N的二进制字符串,它们是子字符串的重复拼接Sep 07, 2023 am 10:13 AM

本文的目的是实现一个程序,用于计算由一个子字符串重复连接而成的长度为N的二进制字符串的数量。目标是确定通过重复连接给定文本的单个子字符串,可以创建多少长度为N的二进制字符串,其中N是一个正整数。问题陈述实现一个程序,用于计算重复连接子字符串的长度为N的二进制字符串的数量。示例示例1LetustaketheInput,N=3Output:2Explanation的中文翻译为:解释下面列出了长度为N=3的可行二进制字符串,其中重复连接了一个子字符串。"000":Thesubstr

将所有0放在1之前所需的最小移动次数在二进制字符串中将所有0放在1之前所需的最小移动次数在二进制字符串中Sep 23, 2023 pm 01:29 PM

问题陈述我们给定了二进制字符串str,我们要求从字符串中删除最少的字符,以便我们可以将所有零放在1之前。示例输入str=‘00110100111’输出3说明这里,我们可以通过两种方式实现输出3。我们可以从字符串中删除arr[2]、arr[3]和arr[5]或arr[4]、arr[6]和arr[7]。输入str=‘001101011’输出2说明我们可以删除arr[4]和arr[6],将所有零放在1之前。输入str=‘000111’输出0说明在给定的字符串中,所有零都已放置在1之前,因此我们不需要从

找到在将一个二进制字符串清空(通过移除非空子字符串)后,0的数量最少的玩家找到在将一个二进制字符串清空(通过移除非空子字符串)后,0的数量最少的玩家Sep 16, 2023 am 10:21 AM

在本文中,我们将讨论一个有趣的问题,涉及到字符串操作和博弈论领域:“通过删除非空子字符串来清空二进制字符串,找到剩余0最少的玩家”。这个问题探索了使用二进制字符串进行竞技游戏的概念。我们的目标是在游戏结束后找出剩余0最少的玩家。我们将讨论这个问题,提供一个C++代码实现,并通过一个例子来解释这个概念。理解问题陈述给两个玩家一个二进制字符串,他们轮流玩游戏。在每一回合中,玩家移除至少包含一个“1”的非空子串。当字符串变空或字符串中没有“1”时,游戏结束。无法采取行动的玩家输掉游戏。任务是找到最终0

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版