From 6cfbbd2bd579071a78a495563041acaee9388ce5 Mon Sep 17 00:00:00 2001 From: fartem Date: Wed, 17 Jul 2024 09:13:46 +0300 Subject: [PATCH] 2024-07-17 v. 6.1.9: added "55. Jump Game" --- README.md | 1 + leetcode-ruby.gemspec | 2 +- lib/medium/55_jump_game.rb | 15 +++++++++++++++ test/medium/test_55_jump_game.rb | 12 ++++++++++++ 4 files changed, 29 insertions(+), 1 deletion(-) create mode 100644 lib/medium/55_jump_game.rb create mode 100644 test/medium/test_55_jump_game.rb diff --git a/README.md b/README.md index eabcb783..e44337eb 100644 --- a/README.md +++ b/README.md @@ -484,3 +484,4 @@ Profile on LeetCode: [fartem](https://leetcode.com/fartem/). | 49. Group Anagrams | [Link](https://leetcode.com/problems/group-anagrams/) | [Link](./lib/medium/49_group_anagrams.rb) | | 53. Maximum Subarray | [Link](https://leetcode.com/problems/maximum-subarray/) | [Link](./lib/medium/53_maximum_subarray.rb) | | 54. Spiral Matrix | [Link](https://leetcode.com/problems/spiral-matrix/) | [Link](./lib/medium/54_spiral_matrix.rb) | +| 55. Jump Game | [Link](https://leetcode.com/problems/jump-game/) | [Link](./lib/medium/55_jump_game.rb) | diff --git a/leetcode-ruby.gemspec b/leetcode-ruby.gemspec index 84190580..821ac513 100644 --- a/leetcode-ruby.gemspec +++ b/leetcode-ruby.gemspec @@ -5,7 +5,7 @@ require 'English' ::Gem::Specification.new do |s| s.required_ruby_version = '>= 3.0' s.name = 'leetcode-ruby' - s.version = '6.1.8' + s.version = '6.1.9' s.license = 'MIT' s.files = ::Dir['lib/**/*.rb'] + %w[bin/leetcode-ruby README.md LICENSE] s.executable = 'leetcode-ruby' diff --git a/lib/medium/55_jump_game.rb b/lib/medium/55_jump_game.rb new file mode 100644 index 00000000..2531ad32 --- /dev/null +++ b/lib/medium/55_jump_game.rb @@ -0,0 +1,15 @@ +# frozen_string_literal: true + +# https://leetcode.com/problems/jump-game/ +# @param {Integer[]} nums +# @return {Boolean} +def can_jump(nums) + reachable = 0 + nums.each_with_index do |n, i| + return false if i > reachable + + reachable = [(n + i), reachable].max + end + + reachable >= nums.length - 1 +end diff --git a/test/medium/test_55_jump_game.rb b/test/medium/test_55_jump_game.rb new file mode 100644 index 00000000..a0d0e3f2 --- /dev/null +++ b/test/medium/test_55_jump_game.rb @@ -0,0 +1,12 @@ +# frozen_string_literal: true + +require_relative '../test_helper' +require_relative '../../lib/medium/55_jump_game' +require 'minitest/autorun' + +class JumpGameTest < ::Minitest::Test + def test_default + assert(can_jump([2, 3, 1, 1, 4])) + assert(!can_jump([3, 2, 1, 0, 4])) + end +end