微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在ruby中用整数递增字符串

假设字符串是“abc”而用户输入是3则输出变为“def”.

应该通过用户输入将每个字符增加为整数值.

我写了一个代码,但它给出了一个错误.有没有其他方法可以做到这一点?

#!/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"

比较慢,但……

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐