|
| 1 | +import interpolationSearch from '../interpolationSearch'; |
| 2 | + |
| 3 | +describe('interpolationSearch', () => { |
| 4 | + it('should search elements in sorted array of numbers', () => { |
| 5 | + expect(interpolationSearch([], 1)).toBe(-1); |
| 6 | + expect(interpolationSearch([1], 1)).toBe(0); |
| 7 | + expect(interpolationSearch([1], 0)).toBe(-1); |
| 8 | + expect(interpolationSearch([1, 1], 1)).toBe(0); |
| 9 | + expect(interpolationSearch([1, 2], 1)).toBe(0); |
| 10 | + expect(interpolationSearch([1, 2], 2)).toBe(1); |
| 11 | + expect(interpolationSearch([10, 20, 30, 40, 50], 40)).toBe(3); |
| 12 | + expect(interpolationSearch([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15], 14)).toBe(13); |
| 13 | + expect(interpolationSearch([1, 6, 7, 8, 12, 13, 14, 19, 21, 23, 24, 24, 24, 300], 24)).toBe(10); |
| 14 | + expect(interpolationSearch([1, 2, 3, 700, 800, 1200, 1300, 1400, 1900], 600)).toBe(-1); |
| 15 | + expect(interpolationSearch([1, 2, 3, 700, 800, 1200, 1300, 1400, 1900], 1)).toBe(0); |
| 16 | + expect(interpolationSearch([1, 2, 3, 700, 800, 1200, 1300, 1400, 1900], 2)).toBe(1); |
| 17 | + expect(interpolationSearch([1, 2, 3, 700, 800, 1200, 1300, 1400, 1900], 3)).toBe(2); |
| 18 | + expect(interpolationSearch([1, 2, 3, 700, 800, 1200, 1300, 1400, 1900], 700)).toBe(3); |
| 19 | + expect(interpolationSearch([1, 2, 3, 700, 800, 1200, 1300, 1400, 1900], 800)).toBe(4); |
| 20 | + expect(interpolationSearch([0, 2, 3, 700, 800, 1200, 1300, 1400, 1900], 1200)).toBe(5); |
| 21 | + expect(interpolationSearch([1, 2, 3, 700, 800, 1200, 1300, 1400, 19000], 800)).toBe(4); |
| 22 | + expect(interpolationSearch([0, 10, 11, 12, 13, 14, 15], 10)).toBe(1); |
| 23 | + }); |
| 24 | +}); |
0 commit comments