- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
给定一个要玩 2 人游戏的 N 名玩家的列表。他们每个人要么精通采取特定行动,要么不精通。找出 2 人团队可以知道的最大步数。
并找出有多少团队可以知道最大步数?
例子假设我们有 4 名玩家,5 步,如果 a[i][j] 为 1,则第 i 位玩家精通第 j 步,否则为 0。
10101
11100
11010
00101
这里一个 2 人团队可以知道的最大步数是 5,他们是两个可以知道最大步数的团队。
解释 : (1, 3) 和 (3, 4) 知道所有 5 步。所以一个 2 人团队知道的最大移动是 5,而且只有 2 个团队可以达到这个目标。
我的方法:对于每对玩家,我检查是否有任何玩家精通 i 步,并为每个玩家保持他可以与其他玩家组成的最大对数及其局部最大值移动组合。
vector<int> pairmemo;
for(int i=0;i<n;i++){
int mymax=INT_MIN;
int countpairs=0;
for(int j=i+1;j<n;j++){
int count=0;
for(int k=0;k<m;k++){
if(arr[i][k]==1 || arr[j][k]==1)
{
count++;
}
}
if(mymax<count){
mymax=count;
countpairs=0;
}
if(mymax==count){
countpairs++;
}
}
pairmemo.push_back(countpairs);
maxmemo.push_back(mymax);
}
所有 N 个玩家的总最大值是答案,计数是正在计算的对的相应总和。
for(int i=0;i<n;i++){
if(maxi<maxmemo[i])
maxi=maxmemo[i];
}
int countmaxi=0;
for(int i=0;i<n;i++){
if(maxmemo[i]==maxi){
countmaxi+=pairmemo[i];
}
}
cout<<maxi<<"\n";
cout<<countmaxi<<"\n";
时间复杂度:O((N^2)*M)
代码:我该如何改进它?
约束条件:N<= 3000 和 M<=1000
最佳答案
如果您用一个非常大的整数表示每组移动,问题归结为找到在 MovesI OR MovesJ
中设置了最大位数的一对玩家 (I, J)。
因此,您可以使用位打包并将所有关于移动的信息压缩到长整型数组中。根据约束需要存储 16 个无符号长整数。因此,对于每对玩家,您可以OR
相应的数组并计算其中的个数。这将花费 O(N^2 * 16) ,在给定约束的情况下运行速度非常快。
例子:假设给定矩阵是
11010
00011
并且您使用了 4 位整数来打包它。它看起来像:
1101-0000
0001-1000
也就是说,
13,0
1,8
在 OR
之后,2 人团队的 moves 数组变为 13,8
,现在计算为 1 的位。您还必须优化位计数,为此请阅读已接受的答案 here , 否则因子 M
会显得复杂。在处理这些对时,只需维护一个计数变量和一个 maxNumberOfBitsSet 变量。
关于c++ - 2 名知道最大步数的玩家团队,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24497535/
这个问题在这里已经有了答案: What does the question mark character ('?') mean in C++? (8 个答案) 关闭 7 年前。 这一行我看不懂为什么
在构建模式下甚至可以有两个玩家吗?查看 Roblox 开发者杂志文章“What did you sleigh?”,它在玩家列表中显示了两个“玩家”。 最佳答案 打开 Roblox Studio 转到任
在构建模式下甚至可以有两个玩家吗?查看 Roblox 开发者杂志文章“What did you sleigh?”,它在玩家列表中显示了两个“玩家”。 最佳答案 打开 Roblox Studio 转到任
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
“Clash of Clans”使用 Game Center 对玩家进行身份验证并将其与现有的远程存储游戏状态相关联。 据我所知,游戏仅在客户端提供玩家标识符。是否有支持的技术来安全地验证用户而不是仅
我正在开发多人游戏,但我无法找出如何将其他客户端连接到创建的游戏。我的意思是客户端 A 创建到服务器的套接字连接,其他客户端(A,B ...)如何连接到客户端 A?有人可以帮我吗? 附注我是网络编程新
我正在尝试使用浏览器控制台一步一步地制作井字游戏,并最终改进我的功能。然而,我被困在玩家2回合(ttt_player2_turn()),我必须检查箱子是否为空。看来我在这个例子中的论证有问题。感谢您的
如果我向上移动玩家 1 和玩家 2,假设我按下玩家 1 的向下键,我的玩家将停止向上移动。我找不到问题所在。有人可以帮助我并解释我做错了什么吗? package game; import java.a
我正在创建一个自上而下的 2D 游戏,并且使用 Box2D 来模拟物理,我的问题是: 如何使玩家保持与我的宇宙飞船的相对速度,并且仍然能够在飞船也在移动的情况下围绕我的玩家移动? 我在下面放了一个插图
我是 Java 新手,我正在尝试制作一个简单的游戏来娱乐。我首先尝试将 repaint 放入 PaintComponent() 中,它一直有效,直到我尝试添加一些背景。有谁知道如何让我的玩家在有或没有
//我正在尝试对玩家 2 的代码进行一些编辑,因此我删除了涉及玩家 1 的所有内容。但出于某种原因,如果没有玩家 1 的代码,玩家 2 根本不会执行任何操作。(假设使用 i、j、k 和 l 键 mov
我接到了一项任务,要编写一个由人类玩家和 AI 玩家组成的 NIM 游戏。游戏是“Misere”(最后一个必须拿起一根棍子的人输了)。 AI 应该使用 Minimax 算法,但它正在采取使其输得更快的
我是一名优秀的程序员,十分优秀!