sortech 0.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. checksums.yaml +7 -0
  2. data/lib/sortech.rb +34 -0
  3. metadata +46 -0
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 20bf6da3c899fd9022e10ab9d54e568914144b7f
4
+ data.tar.gz: bfa48bd50b085aa0988ad83105e3579675060326
5
+ SHA512:
6
+ metadata.gz: a85594d1f0755741f3f1b9123f01e07f40e7fc3446826ca8259cf3419bd9d5bdd448d8f70fdecf0b9d14923dd6adfdb9370fcfa3b60dc6448d774bc21130fb5a
7
+ data.tar.gz: 5eba29495ff5a9e62223062943e59ba37442609541df6722b82ed192caf1ca35983e0cf2d36766b58527a8783ab06275399981a73fc2d901201641646b09626e
@@ -0,0 +1,34 @@
1
+ module Sortech
2
+ class Sort
3
+ class << self
4
+ def bubble(arr)
5
+ arr if arr.length == 0 || is_sorted?(arr)
6
+ n = arr.length
7
+ loop do
8
+ flag = false
9
+ for i in 0..n - 2
10
+ if arr[i] > arr[i+1]
11
+ arr[i] += arr[i+1]
12
+ arr[i+1] = arr[i] - arr[i+1]
13
+ arr[i] = arr[i] - arr[i+1]
14
+ flag = true
15
+ end
16
+ end
17
+ n -= 1
18
+ break unless flag
19
+ end
20
+ arr
21
+ end
22
+
23
+ private
24
+ def is_sorted? arr
25
+ for i in 0..arr.length - 2
26
+ if arr[i] > arr[i+1]
27
+ return false
28
+ end
29
+ end
30
+ true
31
+ end
32
+ end
33
+ end
34
+ end
metadata ADDED
@@ -0,0 +1,46 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: sortech
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.0
5
+ platform: ruby
6
+ authors:
7
+ - Mansoor Khan
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2018-08-11 00:00:00.000000000 Z
12
+ dependencies: []
13
+ description:
14
+ email: thisismansoorkhan@gmail.com
15
+ executables: []
16
+ extensions: []
17
+ extra_rdoc_files: []
18
+ files:
19
+ - lib/sortech.rb
20
+ homepage:
21
+ licenses:
22
+ - MIT
23
+ metadata:
24
+ source_code_uri: https://github.com/steady-daddy/sortech
25
+ post_install_message:
26
+ rdoc_options: []
27
+ require_paths:
28
+ - lib
29
+ required_ruby_version: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ required_rubygems_version: !ruby/object:Gem::Requirement
35
+ requirements:
36
+ - - ">="
37
+ - !ruby/object:Gem::Version
38
+ version: '0'
39
+ requirements: []
40
+ rubyforge_project:
41
+ rubygems_version: 2.6.12
42
+ signing_key:
43
+ specification_version: 4
44
+ summary: Sort an array using different sorting technique
45
+ test_files: []
46
+ has_rdoc: