假设字符串是“abc”而用户输入是3则输出变为“def”. 应该通过用户输入将每个字符增加为整数值. 我写了一个代码,但它给出了一个错误.有没有其他方法可以做到这一点? #!/usr/bin/ru
应该通过用户输入将每个字符增加为整数值.
我写了一个代码,但它给出了一个错误.有没有其他方法可以做到这一点?
#!/usr/bin/ruby -w puts "Enter the value of n"; $n=gets; s = String.new("abc"); s.split("").each do |i| $j = 0; x = i; begin x.next; $j = $j + 1; end while $j < $n puts x; end您的代码中需要添加几项内容:
>而不是String.new,您只需在引号内添加您的字符串即可.
> str.split(“”)可以是str.chars.
> $j = $j 1可以是$j = 1.
>如果您在$j和$n之间进行比较,那么<<应该<.
>你不需要;除非你在一行写作.
>开始;结束虽然可以一会儿;结束
我想这可能是这样的:
n = gets.to_i s = 'abc' s.split('').each do |i| j = 0 x = i while j < n x = x.next j += 1 end puts x end
但是您可以在字符串中的每个字符串上使用String#ord
来返回它的序数,添加用户输入,然后使用String#chr
获取该数字的ASCII字符:
# With n being the user's input as integer, in this case 3. p 'abc'.chars.map { |char| (char.ord + n).chr }.join # "def"
添加了n = gets.to_i,如@Ganesh的评论中所述.
如果要寻找Caesar Cipher实现:
def foo(string, n) lower = ('a'..'z').to_a.join upper = ('A'..'Z').to_a.join string.tr(lower + upper, lower[n..-1] + lower[0...n] + upper[n..-1] + upper[0...n]) end p foo('XYZ', 1) # "YZA" p foo('ABC', 1) # "BCD" p foo('ABC', 3) # "DEF"
比较慢,但……