![](https://cdn-ak-scissors.b.st-hatena.com/image/square/c94b4e1245730400013dbe91c1e0b5658924a740/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9Q29kZUlRJTIwJUU0JUI4JUFEJUU1JUFEJUE2JUU1JTg1JUE1JUU4JUE5JUE2JUUzJTgxJThCJUUzJTgyJTg5JUVGJUJDJTlBJUU1JThEJTk4JUU0JUJEJThEJUUzJTgxJUFFJUUzJTgxJTgyJUUzJTgyJThCJUU4JUE4JTg4JUU3JUFFJTk3JUUzJTgyJTkyUnVieSVFMyU4MSVBNyVFOCVBNyVBMyVFMyU4MSU4RiZ0eHQtY29sb3I9JTIzMjEyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTU2JnR4dC1jbGlwPWVsbGlwc2lzJnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnM9NzMzNGE0MzY5ZmEwZDk4ZTYzOTM5OGZjNDEwNTc2Yjg%26mark-x%3D142%26mark-y%3D112%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQwbmlkb3VjaGkmdHh0LWNvbG9yPSUyMzIxMjEyMSZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT0zNiZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZzPWI0ZTc1OGZhZjgyOGM1YWY5NWNhYjk3NDdkMTdkNDZi%26blend-x%3D142%26blend-y%3D491%26blend-mode%3Dnormal%26s%3De0e52ec68ad099b786f3fbcbf3ad1ef4)
エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
記事へのコメント1件
- 注目コメント
- 新着コメント
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
CodeIQ 中学入試から:単位のある計算をRubyで解く - Qiita
# -*- coding: utf-8 -*- CV = { '日'=>24*60*60,'時間'=>60*60,'分'=>60,'秒'=>1, 'km'=>1000*100*10,'... # -*- coding: utf-8 -*- CV = { '日'=>24*60*60,'時間'=>60*60,'分'=>60,'秒'=>1, 'km'=>1000*100*10,'m'=>100*10,'cm'=>10,'mm'=>1, 'kg'=>1000000,'g'=>1000,'mg'=>1, } def to_unit(s) s.scan(/\d+[^\d]+/).inject(0) {|sum, e| e =~ /(\d+)(.+)/ sum += $1.to_i * CV[$2] } * (s[0] == '-' ? -1 : 1) end def solve(q) l_sum, r_sum = q.split('=').map{|s| s.scan(/[+-]?\d+[^+-]+/).inject(0){|sum, e| sum += to_unit(e)} } x_p
2014/09/25 リンク