212 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
		
		
			
		
	
	
			212 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
|   | --- | ||
|  | id: 5e4ce2b6ac708cc68c1df25e | ||
|  | title: Last letter-first letter | ||
|  | challengeType: 5 | ||
|  | forumTopicId: 385256 | ||
|  | dashedName: last-letter-first-letter | ||
|  | --- | ||
|  | 
 | ||
|  | # --description--
 | ||
|  | 
 | ||
|  | A certain children's game involves starting with a word in a particular category. Each participant in turn says a word, but that word must begin with the final letter of the previous word. Once a word has been given, it cannot be repeated. If an opponent cannot give a word in the category, they fall out of the game. | ||
|  | 
 | ||
|  | For example, with "animals" as the category, | ||
|  | 
 | ||
|  | <pre>Child 1: dog | ||
|  | Child 2: goldfish | ||
|  | Child 1: hippopotamus | ||
|  | Child 2: snake | ||
|  | ... | ||
|  | </pre> | ||
|  | 
 | ||
|  | # --instructions--
 | ||
|  | 
 | ||
|  | Write a function that takes an input array of words. The function should return an array of words where the first letter of each word is the same as the last letter of the previous word. Only use the words in the input array, and once a word is used it cannot be repeated. The words in the return array should be selected and sequenced so that that its length is maximized. | ||
|  | 
 | ||
|  | # --hints--
 | ||
|  | 
 | ||
|  | `findLongestChain` should be a function. | ||
|  | 
 | ||
|  | ```js | ||
|  | assert(typeof findLongestChain == 'function'); | ||
|  | ``` | ||
|  | 
 | ||
|  | `findLongestChain(["certain", "each", "game", "involves", "starting", "with", "word"])` should return an array. | ||
|  | 
 | ||
|  | ```js | ||
|  | assert( | ||
|  |   Array.isArray( | ||
|  |     findLongestChain([ | ||
|  |       'certain', | ||
|  |       'each', | ||
|  |       'game', | ||
|  |       'involves', | ||
|  |       'starting', | ||
|  |       'with', | ||
|  |       'word' | ||
|  |     ]) | ||
|  |   ) | ||
|  | ); | ||
|  | ``` | ||
|  | 
 | ||
|  | `findLongestChain(["certain", "each", "game", "involves", "starting", "with", "word"])` should return `["involves", "starting", "game", "each"]`. | ||
|  | 
 | ||
|  | ```js | ||
|  | assert.deepEqual( | ||
|  |   findLongestChain([ | ||
|  |     'certain', | ||
|  |     'each', | ||
|  |     'game', | ||
|  |     'involves', | ||
|  |     'starting', | ||
|  |     'with', | ||
|  |     'word' | ||
|  |   ]), | ||
|  |   ['involves', 'starting', 'game', 'each'] | ||
|  | ); | ||
|  | ``` | ||
|  | 
 | ||
|  | `findLongestChain(["audino", "bagon", "kangaskhan", "banette", "bidoof", "braviary", "exeggcute", "yamask"])` should return `["braviary", "yamask", "kangaskhan"]` | ||
|  | 
 | ||
|  | ```js | ||
|  | assert.deepEqual( | ||
|  |   findLongestChain([ | ||
|  |     'audino', | ||
|  |     'bagon', | ||
|  |     'kangaskhan', | ||
|  |     'banette', | ||
|  |     'bidoof', | ||
|  |     'braviary', | ||
|  |     'exeggcute', | ||
|  |     'yamask' | ||
|  |   ]), | ||
|  |   ['braviary', 'yamask', 'kangaskhan'] | ||
|  | ); | ||
|  | ``` | ||
|  | 
 | ||
|  | `findLongestChain(["harp", "poliwrath", "poochyena", "porygon2", "porygonz", "archana"])` should return `["poliwrath", "harp", "poochyena", "archana"]`. | ||
|  | 
 | ||
|  | ```js | ||
|  | assert.deepEqual( | ||
|  |   findLongestChain([ | ||
|  |     'harp', | ||
|  |     'poliwrath', | ||
|  |     'poochyena', | ||
|  |     'porygon2', | ||
|  |     'porygonz', | ||
|  |     'archana' | ||
|  |   ]), | ||
|  |   ['poliwrath', 'harp', 'poochyena', 'archana'] | ||
|  | ); | ||
|  | ``` | ||
|  | 
 | ||
|  | `findLongestChain(["scolipede", "elephant", "zeaking", "sealeo", "silcoon", "tigers"])` should return `["scolipede", "elephant", "tigers", "sealeo"]`. | ||
|  | 
 | ||
|  | ```js | ||
|  | assert.deepEqual( | ||
|  |   findLongestChain([ | ||
|  |     'scolipede', | ||
|  |     'elephant', | ||
|  |     'zeaking', | ||
|  |     'sealeo', | ||
|  |     'silcoon', | ||
|  |     'tigers' | ||
|  |   ]), | ||
|  |   ['scolipede', 'elephant', 'tigers', 'sealeo'] | ||
|  | ); | ||
|  | ``` | ||
|  | 
 | ||
|  | `findLongestChain(["loudred", "lumineon", "lunatone", "machamp", "magnezone", "nosepass", "petilil", "pidgeotto", "pikachu"])` should return `["machamp", "petilil", "lumineon", "nosepass"]`. | ||
|  | 
 | ||
|  | ```js | ||
|  | assert.deepEqual( | ||
|  |   findLongestChain([ | ||
|  |     'loudred', | ||
|  |     'lumineon', | ||
|  |     'lunatone', | ||
|  |     'machamp', | ||
|  |     'magnezone', | ||
|  |     'nosepass', | ||
|  |     'petilil', | ||
|  |     'pidgeotto', | ||
|  |     'pikachu' | ||
|  |   ]), | ||
|  |   ['machamp', 'petilil', 'lumineon', 'nosepass'] | ||
|  | ); | ||
|  | ``` | ||
|  | 
 | ||
|  | # --seed--
 | ||
|  | 
 | ||
|  | ## --seed-contents--
 | ||
|  | 
 | ||
|  | ```js | ||
|  | function findLongestChain(items) { | ||
|  | 
 | ||
|  | } | ||
|  | ``` | ||
|  | 
 | ||
|  | # --solutions--
 | ||
|  | 
 | ||
|  | ```js | ||
|  | function findLongestChain(items) { | ||
|  |   function Ref(index, first_char, last_char) { | ||
|  |     this.index = index; | ||
|  |     this.first_char = first_char; | ||
|  |     this.last_char = last_char; | ||
|  |   } | ||
|  | 
 | ||
|  |   var items_len = items.length | ||
|  |   var refs_len = items_len; | ||
|  |   var refs = [] | ||
|  | 
 | ||
|  |   // enough space for all items | ||
|  |   var longest_path_refs_len = 0; | ||
|  |   var longest_path_refs = new Array(items_len); | ||
|  | 
 | ||
|  |   function search(curr_len) { | ||
|  |     if (curr_len > longest_path_refs_len) { | ||
|  |       longest_path_refs_len = curr_len; | ||
|  | 
 | ||
|  |       for (var i = 0; i < curr_len; i++) { | ||
|  |         longest_path_refs[i] = refs[i]; | ||
|  |       } | ||
|  |     } | ||
|  | 
 | ||
|  |     // recursive search | ||
|  |     var last_char = refs[curr_len - 1].last_char; | ||
|  |     for (var i = curr_len; i < refs_len; i++) | ||
|  |       if (refs[i].first_char == last_char) { | ||
|  |         var aux = refs[curr_len]; | ||
|  |         refs[curr_len] = refs[i]; | ||
|  |         refs[i] = aux; | ||
|  |         search(curr_len + 1); | ||
|  |         refs[i] = refs[curr_len]; | ||
|  |         refs[curr_len] = aux; | ||
|  |       } | ||
|  |   } | ||
|  | 
 | ||
|  |   for (var i = 0; i < items_len; i++) { | ||
|  |     var itemsi_len = items[i].length; | ||
|  |     refs.push(new Ref(i, items[i][0], items[i][itemsi_len - 1])); | ||
|  |   } | ||
|  | 
 | ||
|  |   // try each item as possible start | ||
|  |   for (var i = 0; i < items_len; i++) { | ||
|  |     var aux = refs[0]; | ||
|  |     refs[0] = refs[i]; | ||
|  |     refs[i] = aux; | ||
|  |     search(1); | ||
|  |     refs[i] = refs[0]; | ||
|  |     refs[0] = aux; | ||
|  |   } | ||
|  | 
 | ||
|  |   var longest_path_len = longest_path_refs_len; | ||
|  |   var longest_path = new Array(longest_path_len); | ||
|  | 
 | ||
|  |   for (var i = 0; i < longest_path_len; i++) | ||
|  |     longest_path[i] = items[longest_path_refs[i].index]; | ||
|  | 
 | ||
|  |   return longest_path; | ||
|  | } | ||
|  | ``` |