6 kyu

Tribonacci Sequence

61,800 of 160,595GiacomoSorbi

Description:

Well met with Fibonacci bigger brother, AKA Tribonacci.

As the name may already reveal, it works basically like a Fibonacci, but summing the last 3 (instead of 2) numbers of the sequence to generate the next. And, worse part of it, regrettably I won't get to hear non-native Italian speakers trying to pronounce it :(

So, if we are to start our Tribonacci sequence with [1, 1, 1] as a starting input (AKA signature), we have this sequence:

[1, 1 ,1, 3, 5, 9, 17, 31, ...]

But what if we started with [0, 0, 1] as a signature? As starting with [0, 1] instead of [1, 1] basically shifts the common Fibonacci sequence by once place, you may be tempted to think that we would get the same sequence shifted by 2 places, but that is not the case and we would get:

[0, 0, 1, 1, 2, 4, 7, 13, 24, ...]

Well, you may have guessed it by now, but to be clear: you need to create a fibonacci function that given a signature array/list, returns the first n elements - signature included of the so seeded sequence.

Signature will always contain 3 numbers; n will always be a non-negative number; if n == 0, then return an empty array (except in C return NULL) and be ready for anything else which is not clearly specified ;)

If you enjoyed this kata more advanced and generalized version of it can be found in the Xbonacci kata

[Personal thanks to Professor Jim Fowler on Coursera for his awesome classes that I really recommend to any math enthusiast and for showing me this mathematical curiosity too with his usual contagious passion :)]

Number Theory
Arrays
Lists
Fundamentals

Stats:

CreatedJun 2, 2015
PublishedJun 2, 2015
Warriors Trained346794
Total Skips63592
Total Code Submissions631136
Total Times Completed160595
Python Completions61800
JavaScript Completions47565
Ruby Completions4759
Haskell Completions1919
Java Completions14288
CoffeeScript Completions94
C# Completions8515
Elixir Completions449
F# Completions180
OCaml Completions122
Crystal Completions42
PHP Completions3171
Swift Completions1114
C++ Completions8156
Scala Completions345
Kotlin Completions845
C Completions2440
Rust Completions1757
Reason Completions11
Elm Completions47
Clojure Completions203
Go Completions1848
TypeScript Completions2591
Dart Completions852
Factor Completions20
Groovy Completions46
Julia Completions110
R Completions129
Racket Completions54
COBOL Completions11
D Completions9
Total Stars3360
% of votes with a positive feedback rating89% of 14844
Total "Very Satisfied" Votes12032
Total "Somewhat Satisfied" Votes2483
Total "Not Satisfied" Votes329
Ad
Contributors
  • GiacomoSorbi Avatar
  • jhoffner Avatar
  • hbakhtiyor Avatar
  • spencerwi Avatar
  • Bodigrim Avatar
  • Unnamed Avatar
  • baliuk91@gmail.com Avatar
  • anter69 Avatar
  • nbeck Avatar
  • Chrono79 Avatar
  • kazk Avatar
  • Blind4Basics Avatar
  • DonVito1982 Avatar
  • ryancastle Avatar
  • wneumann Avatar
  • Voile Avatar
  • kzm Avatar
  • rowcased Avatar
  • FArekkusu Avatar
  • monadius Avatar
  • della-90 Avatar
  • user9644768 Avatar
  • hobovsky Avatar
  • cliffstamp Avatar
  • qwertyu123 Avatar
  • user8436785 Avatar
  • ejini战神 Avatar
  • akar-0 Avatar
  • yLaWy Avatar
  • KayleighWasTaken Avatar
Ad