- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
start(i=2 to max) --> 如果任何测试对为 T-6ren">
我有一个指定“桥牌游戏”的数据框(每一行都是一个独立的游戏),请参阅下面的 4 个游戏的最小示例:
start <- list(c("10","15","5"), c("5") ,c("11","6"),c("6","11"))
end <- list(c("7","17","11"), c("10"), c("8","12"),c("8","12"))
ascending <- c("+","-","+","-")
position <- c(11,6,9,8)
desired_output <- c(5,5,"disqualified",3)
bridge_game <- data.frame(start = I(start), end = I(end), ascending = ascending, position = position, desired_output = desired_output)
bridge_game
桥牌游戏如何运作?全世界的考生都参加了桥牌比赛挑战,我们在数据框中收集了每场桥牌比赛的数据。每座桥都由编号的木板(不一定必须从 1 开始的正整数)和 splinter 板的“间隙”组成。候选人可以选择从桥的哪一侧开始步行(升序 = 面板编号随着步行的进行而增加;或下降 = 面板的编号随着步行的进行而减少)。
可以在此处找到用于更好理解桥牌游戏的图形(以数据框中的第一行为例): click here
对于每个桥牌游戏(= 数据框中的行),我们有以下信息(= 列):
挑战是什么?我需要编写一个脚本,我可以在整个数据帧上逐行运行以获得以下输出:
重要的是,它应该适用于任意数量的i整片木板。
更准确地说,我在下面给出了请求的 R 脚本应该如何操作的分步说明:
0) 已解决
a) 将字符列表转换为 bridge_game$start 和 bridge_game$end 列的数字列表。
b) 计算i(整 block 木板的条数;i从1到i=max 为每一行)并对开始和结束位置进行排序以获得每个 i 的正确开始和结束值。
1) 测试位置是否在 splinter 面板:end(i=1 to max-1) > position > start(i=2 to max) --> 如果任何测试对为 TRUE --> “不合格”
2) 如果否,则测试给定位置位于整个面板的哪个区域 (i = n):start(i=1 to max) <= position <= end(i=1 to max) --> 如果 TRUE 则返回 i (= n)
3)
a) 应用此公式(如果方向为升序“+”且 n = 1):输出 = 位置 - 开始 (i=1) + 1
b) 应用这个公式(如果方向是下降的“-”并且 n = i max):output = end(i=max) - position + 1
c)应用这个公式(如果方向是升序“+”并且 n > 1):输出 = 位置 - 开始(i=1)+ 1 -(开始(i=2 到 n) - 结束( i=1 到 n-1) - 1x[n-1])
d) 应用这个公式(如果方向是下降的“-”并且 n < i max):output = end(i=max) - position + 1 - (start(i=n+1 to max) - end(i=n to max-1) - 1x[i=max - n])
我希望我在那里得到了数学。为了检查正确的输出,我在“bridge_game”数据框中创建了一个“desired_output”列。
感谢您的帮助!
最佳答案
你把这个问题复杂化了。考虑以下实现
parse_pos <- function(x) sort(as.integer(x))
construct_bridge <- function(starts, ends) {
starts <- parse_pos(starts); ends <- parse_pos(ends)
bridge <- logical(tail(ends, 1L))
whole_panels <- sequence(ends - starts + 1L, starts)
bridge[whole_panels] <- TRUE
bridge
}
count_steps <- function(bridge, direction, stop_pos) {
if (isFALSE(bridge[[stop_pos]]))
return("disqualified")
start_pos = c("+" = 1L, "-" = length(bridge))[[direction]]
sum(bridge[start_pos:stop_pos])
}
play_games <- function(starts, ends, direction, stop_pos) {
mapply(function(s, e, d, sp) {
bridge <- construct_bridge(s, e)
count_steps(bridge, d, sp)
}, starts, ends, direction, stop_pos)
}
输出
> with(bridge_game, play_games(start, end, ascending, position))
[1] "5" "5" "disqualified" "3"
这里的关键是我们可以使用一个逻辑向量来表示一个桥,其中一个损坏的/整个面板由 F
/T
索引。然后我们只是测试停止位置是否在整个面板上。如果是,则返回从开始位置到结束位置的面板总和(损坏的面板不会影响总和,因为它们只是零),否则返回“不合格”。
关于R 编程,使用自定义脚本(针对每个 i)进行逐行数据帧计算以解决 "bridge game",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65003498/
猫f1.txt阿曼维沙尔阿杰贾伊维杰拉胡尔曼尼什肖比特批评塔夫林现在输出应该符合上面给定的条件 最佳答案 您可以在文件读取循环中设置一个计数器并打印它, 计数=0 读取行时做 让我们数一数++ if
我正在尝试查找文件 1 和文件 2 中的共同行。如果公共(public)行存在,我想写入文件 2 中的行,否则打印文件 1 中的非公共(public)行。fin1 和 fin2 是这里的文件句柄。它读
我有这个 SQL 脚本: CREATE TABLE `table_1` ( `IDTable_1` int(11) NOT NULL, PRIMARY KEY (`IDTable_1`) );
我有 512 行要插入到数据库中。我想知道提交多个插入内容是否比提交一个大插入内容有任何优势。例如 1x 512 行插入 -- INSERT INTO mydb.mytable (id, phonen
如何从用户中选择user_id,SUB(row, row - 1),其中user_id=@userid我的表用户,id 为 1、3、4、10、11、23...(不是++) --id---------u
我曾尝试四处寻找解决此问题的最佳方法,但我找不到此类问题的任何先前示例。 我正在构建一个基于超本地化的互联网购物中心,该区域分为大约 3000 个区域。每个区域包含大约 300 个项目。它们是相似的项
preg_match('|phpVersion = (.*)\n|',$wampConfFileContents,$result); $phpVersion = str_replace('"','',
我正在尝试创建一个正则表达式,使用“搜索并替换全部”删除 200 个 txt 文件的第一行和最后 10 行 我尝试 (\s*^(\h*\S.*)){10} 删除包含的前 10 行空白,但效果不佳。 最
下面的代码从数据库中获取我需要的信息,但没有打印出所有信息。首先,我知道它从表中获取了所有正确的信息,因为我已经在 sql Developer 中尝试过查询。 public static void m
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我试图在两个表中插入记录,但出现异常。您能帮我解决这个问题吗? 首先我尝试了下面的代码。 await _testRepository.InsertAsync(test); await _xyzRepo
这个基本的 bootstrap CSS 显示 1 行 4 列: Text Text Text
如果我想从表中检索前 10 行,我将使用以下代码: SELECT * FROM Persons LIMIT 10 我想知道的是如何检索前 10 个结果之后的 10 个结果。 如果我在下面执行这段代码,
今天我开始使用 JexcelApi 并遇到了这个:当您尝试从特定位置获取元素时,不是像您通常期望的那样使用sheet.getCell(row,col),而是使用sheet.getCell(col,ro
我正在尝试在我的网站上开发一个用户个人资料系统,其中包含用户之前发布的 3 个帖子。我可以让它选择前 3 条记录,但它只会显示其中一条。我是不是因为凌晨 2 点就想编码而变得愚蠢? query($q)
我在互联网上寻找答案,但找不到任何答案。 (我可能问错了?)我有一个看起来像这样的表: 我一直在使用查询: SELECT title, date, SUM(money) FROM payments W
我有以下查询,我想从数据库中获取 100 个项目,但 host_id 多次出现在 urls 表中,我想每个 host_id 从该表中最多获取 10 个唯一行。 select * from urls j
我的数据库表中有超过 500 行具有特定日期。 查询特定日期的行。 select * from msgtable where cdate='18/07/2012' 这将返回 500 行。 如何逐行查询
我想使用 sed 从某一行开始打印 n 行、跳过 n 行、打印 n 行等,直到文本文件结束。例如在第 4 行声明,打印 5-9,跳过 10-14,打印 15-19 等 来自文件 1 2 3 4 5 6
我目前正在执行验证过程来检查用户的旧密码,但问题是我无法理解为什么我的查询返回零行,而预期它有 1 行。另一件事是,即使我不将密码文本转换为 md5,哈希密码仍然得到正确的答案,但我不知道为什么会发生
我是一名优秀的程序员,十分优秀!