- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我有一个函数,它打算通过在任何奇数整数之前或之后插入一个“-”来获取一个整数并返回一个字符串,但输出字符串的开头或结尾没有“-”。
这是我的函数(抱歉,这不是惯用的 ruby!):
def dash_odds(num)
arr = num.to_s.split("").map {|digit| digit.to_i}
string = ""
i = 0
while i < arr.length
if arr[i] % 2 == 0
string = string + arr[i].to_s
elsif arr[i].to_s % 2 != 0
new = "-" << arr[i].to_s unless i == 0
string = string + new.to_s
else arr[i].to_s % 2 != 0
new = arr[i].to_s << "-" unless i == -1
string = string + new.to_s
end
i += 1
end
return string
end
例如,dash_odds(5227) 应该正确地产生“5-22-7”,但却返回“22-7”。
但是,这对于以偶数开头的整数来说不是问题(即输入 2222 或 227 yield ,分别为“2222”和“22-7”,正如预期的那样)。
最佳答案
嘿,这感觉有点傻,但确实有效
s.scan(/[13579]|[24680]+/).join('-')
解释
这样做的目的是将字符串拆分为一个字符串数组,其中包含单个奇数位 ([13579]
) 或一组偶数位 ([24680]+
)。 +
匹配一位或多位数字,因此允许偶数位组合在一起,而奇数位保持分开。
"5227".scan(/[13579]|[24680]+/)
=> ["5", "22", "7"]
"632273170088".scan(/[13579]|[24680]+/)
=> ["6", "3", "22", "7", "3", "1", "7", "0088"]
然后使用 join
重建每组之间带有破折号的字符串。
["5", "22", "7"].join('-')
=> "5-22-7"
此代码假定输入字符串。如果你有数字输入,你必须先调用to_s
。
OP的代码
我想我还要对最初发布的代码中的一些错误发表评论。
首先,else
不采用条件表达式。起初我很惊讶它没有产生错误,直到我意识到它被解释为
else
arr[i].to_s % 2 != 0 # **Boolean expression with no side effect**
new = arr[i].to_s << "-" unless i == -1
string = string + new.to_s
它在看到表达式之前已经进入了 else block 。然后表达式像任何其他语句一样处理,它计算表达式然后丢弃结果。 (除非它是 block 中唯一的表达式,在这种情况下,结果将作为 block 的值返回)。
即使将 else
更改为 elsif
,它仍然无法工作,因为条件与之前的 elsif
相同因此最后一个 block 永远不会执行,因为前面的 block 总是会捕获该条件。
if exp1
puts 'exp1 true'
elsif exp2
puts 'exp2 true'
elsif exp2 # Duplicate expression
puts 'exp2 true (2)' # Never executed, case already caught above
end
另一个问题是条件表达式 arr[i].to_s % 2 != 0
在 %
之前使用了 to_s
。这意味着整数的模运算,但字符串的字符串插值。这就像调用 sprintf(string, args)
。
5 % 2
=> 1
'A number: %d' % 2
=> "A number: 2"
当然,该表达式是为了测试偶数或奇数,所以一个简单的 else
就可以了。
在 else 中,您可以使用嵌套条件来测试位置(开始或结束),但如果您有连续的奇数,那么您将处于重复破折号的领域。我一直在避免尝试解决的问题。
关于ruby - 为什么我的条件语句有选择地删除输出字符串中的第一个字符?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34124409/
是否有某种方法可以使用 JPA 或 Hibernate Crtiteria API 来表示这种 SQL?或者我应该将其作为 native 执行吗? SELECT A.X FROM (SELECT X,
在查询中, select id,name,feature,marks from (....) 我想删除其 id 在另一个 select 语句中存在的那些。 从 (...) 中选择 id 我是 sql
我想响应用户在 select 元素中选择一个项目。然而这个 jQuery: $('#platypusDropDown').select(function () { alert('You sel
这个问题在这里已经有了答案: SQL select only rows with max value on a column [duplicate] (27 个回答) 关闭8年前。 我正在学习 SQL
This question already has answers here: “Notice: Undefined variable”, “Notice: Undefined index”, and
我在 php 脚本中调用 SQL。有时“DE”中没有值,如果是这种情况我想从“EN”中获取值 应该是这样的,但不是这样的 IF (EXISTS (SELECT epf_application_deta
这可能是一个奇怪的问题,但不知道如何研究它。执行以下查询时: SELECT Foo.col1, Foo.col2, Foo.col3 FROM Foo INNER JOIN Bar ON
如何在使用 Camera.DestinationType.FILE_URI. 时在 phonegap camera API 中同时选择或拾取多个图像我能够一次只选择一张图像。我可以使用 this 在
这是一个纯粹的学术问题。这两个陈述实际上是否相同? IF EXISTS (SELECT TOP 1 1 FROM Table1) SELECT 1 ELSE SELECT 0 相对 IF EXIS
我使用 JSoup 来解析 HTML 响应。我有多个 Div 标签。我必须根据 ID 选择 Div 标签。 我的伪代码是这样的 Document divTag = Jsoup.connect(link
我正在处理一个具有多个选择框的表单。当用户从 selectbox1 中选择一个选项时,我需要 selectbox2 active 的另一个值。同样,当他选择 selectbox2 的另一个值时,我需要
Acme Inc. Christa Woods Charlotte Freeman Jeffrey Walton Ella Hubbard Se
我有一个login.html其中form定义如下: First Initial Plus Last Name : 我的do_authorize如下: "; pri
$.get( 'http://www.ufilme.ro/api/load/maron_online/470', function(data
我有一个下拉列表“磅”、“克”、“千克”和“盎司”。我想要这样一种情况,当我选择 gram 来执行一个函数时,当我在输入字段中输入一个值时,当我选择 pounds 时,我想要另一个函数来执行时我在输入
我有一个 GLSL 着色器,它从输入纹理的 channel 之一(例如 R)读取,然后写入输出纹理中的同一 channel 。该 channel 必须由用户选择。 我现在能想到的就是使用一个 int
我想根据下拉列表中的选定值生成输入文本框。 Options 2 3 4 5 就在这个选择框之后,一些输入字段应该按照选定的数字出现。 最佳答案 我建议您使用响应式(Reac
我是 SQL 新手,我想问一下如何根据首选项和分组选择条目。 +----------+----------+------+ | ENTRY_ID | ROUTE_ID | TYPE | +------
我有以下表结构: CREATE TABLE [dbo].[UTS_USERCLIENT_MAPPING_USER_LIST] ( [MAPPING_ID] [int] IDENTITY(1,1
我在移除不必要的床单时遇到了问题。我查看了不同的论坛并将不同的解决方案混合在一起。 此宏删除工作表(第一张工作表除外)。 Sub wrong() Dim sht As Object Applicati
我是一名优秀的程序员,十分优秀!