Merge 6583a7abf0 into a05d4d60c8
				
					
				
			This commit is contained in:
		
						commit
						9339c108aa
					
				|  | @ -1,5 +1,5 @@ | |||
| const helloWorld = function() { | ||||
|   return '' | ||||
|   return 'Hello, World!' | ||||
| }; | ||||
| 
 | ||||
| module.exports = helloWorld; | ||||
|  |  | |||
|  | @ -10,7 +10,7 @@ This function will take two arguments, `string` and `num`. | |||
| 
 | ||||
| *Note:* The exercises after this one will not have arguments provided as this one does - you will need to provide them yourself from now on. So read each exercise's README carefully to see what kinds of arguments will be expected. | ||||
| 
 | ||||
| You will notice in this exercise that there are multiple tests (see in file `repeatString.spec.js`). Only the first test is currently enabled. So after making sure that this first one passes, enable the others one by one by deleting the `.skip` from the `test.skip()` function. | ||||
| You will notice in this exercise that there are multiple tests (see in file `repeatString.spec.js`). Only the first test is currently enabled. So after making sure that this first one passes, enable the others one by one by deleting the `` from the `test()` function. | ||||
| 
 | ||||
| 
 | ||||
| ## Hints | ||||
|  |  | |||
|  | @ -1,5 +1,9 @@ | |||
| const repeatString = function() { | ||||
| 
 | ||||
| const repeatString = function(string, num) { | ||||
|     if (num < 0) { | ||||
|         return "ERROR"; | ||||
|     } else { | ||||
|         return string.repeat(num);  | ||||
|     } | ||||
| }; | ||||
| 
 | ||||
| // Do not edit below this line
 | ||||
|  |  | |||
|  | @ -4,19 +4,19 @@ describe('repeatString', () => { | |||
|   test('repeats the string', () => { | ||||
|     expect(repeatString('hey', 3)).toEqual('heyheyhey'); | ||||
|   }); | ||||
|   test.skip('repeats the string many times', () => { | ||||
|   test('repeats the string many times', () => { | ||||
|     expect(repeatString('hey', 10)).toEqual('heyheyheyheyheyheyheyheyheyhey'); | ||||
|   }); | ||||
|   test.skip('repeats the string 1 times', () => { | ||||
|   test('repeats the string 1 times', () => { | ||||
|     expect(repeatString('hey', 1)).toEqual('hey'); | ||||
|   }); | ||||
|   test.skip('repeats the string 0 times', () => { | ||||
|   test('repeats the string 0 times', () => { | ||||
|     expect(repeatString('hey', 0)).toEqual(''); | ||||
|   }); | ||||
|   test.skip('returns ERROR with negative numbers', () => { | ||||
|   test('returns ERROR with negative numbers', () => { | ||||
|     expect(repeatString('hey', -1)).toEqual('ERROR'); | ||||
|   }); | ||||
|   test.skip('repeats the string a random amount of times', function () { | ||||
|   test('repeats the string a random amount of times', function () { | ||||
|     /*The number is generated by using Math.random to get a value from between | ||||
|     0 to 1, when this is multiplied by 1000 and rounded down with Math.floor it  | ||||
|     equals a number between 0 to 999 (this number will change everytime you run | ||||
|  | @ -31,7 +31,7 @@ describe('repeatString', () => { | |||
|     was randomly generated. */ | ||||
|     expect(repeatString('hey', number).match(/((hey))/g).length).toEqual(number); | ||||
|   }); | ||||
|   test.skip('works with blank strings', () => { | ||||
|   test('works with blank strings', () => { | ||||
|     expect(repeatString('', 10)).toEqual(''); | ||||
|   }); | ||||
| }); | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ Pretty simple, write a function called `reverseString` that returns its input, r | |||
| reverseString('hello there') // returns 'ereht olleh' | ||||
| ``` | ||||
| 
 | ||||
| You will notice in this exercise that there are multiple tests, after making the first one pass, enable the others one by one by deleting the `.skip` in front the `test.skip()` function. | ||||
| You will notice in this exercise that there are multiple tests, after making the first one pass, enable the others one by one by deleting the `` in front the `test()` function. | ||||
| 
 | ||||
| ## Hints | ||||
| Strings in JavaScript cannot be reversed directly so you're going to have to split it into something else first.. do the reversal and then join it back together into a string. | ||||
|  |  | |||
|  | @ -1,5 +1,9 @@ | |||
| const reverseString = function() { | ||||
| const reverseString = function(string) { | ||||
| //Convert String to Array
 | ||||
| //Reverse Array
 | ||||
|     return string.split('').reverse().join('').toString(); | ||||
| 
 | ||||
| //Join & Convert to String
 | ||||
| }; | ||||
| 
 | ||||
| // Do not edit below this line
 | ||||
|  |  | |||
|  | @ -5,14 +5,14 @@ describe('reverseString', () => { | |||
|     expect(reverseString('hello')).toEqual('olleh'); | ||||
|   }); | ||||
| 
 | ||||
|   test.skip('reverses multiple words', () => { | ||||
|   test('reverses multiple words', () => { | ||||
|     expect(reverseString('hello there')).toEqual('ereht olleh') | ||||
|   }) | ||||
| 
 | ||||
|   test.skip('works with numbers and punctuation', () => { | ||||
|   test('works with numbers and punctuation', () => { | ||||
|     expect(reverseString('123! abc!')).toEqual('!cba !321') | ||||
|   }) | ||||
|   test.skip('works with blank strings', () => { | ||||
|   test('works with blank strings', () => { | ||||
|     expect(reverseString('')).toEqual('') | ||||
|   }) | ||||
| }); | ||||
|  |  | |||
|  | @ -1,4 +1,8 @@ | |||
| const removeFromArray = function() { | ||||
| const removeFromArray = function(list, ...remove) { | ||||
| 
 | ||||
|     let result = list.filter(item => !remove.includes(item)); | ||||
| 
 | ||||
|     return result; | ||||
|      | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
|  | @ -4,22 +4,22 @@ describe('removeFromArray', () => { | |||
|   test('removes a single value', () => { | ||||
|     expect(removeFromArray([1, 2, 3, 4], 3)).toEqual([1, 2, 4]); | ||||
|   }); | ||||
|   test.skip('removes multiple values', () => { | ||||
|   test('removes multiple values', () => { | ||||
|     expect(removeFromArray([1, 2, 3, 4], 3, 2)).toEqual([1, 4]); | ||||
|   }); | ||||
|   test.skip('ignores non present values', () => { | ||||
|   test('ignores non present values', () => { | ||||
|     expect(removeFromArray([1, 2, 3, 4], 7, "tacos")).toEqual([1, 2, 3, 4]); | ||||
|   }); | ||||
|   test.skip('ignores non present values, but still works', () => { | ||||
|   test('ignores non present values, but still works', () => { | ||||
|     expect(removeFromArray([1, 2, 3, 4], 7, 2)).toEqual([1, 3, 4]); | ||||
|   }); | ||||
|   test.skip('can remove all values', () => { | ||||
|   test('can remove all values', () => { | ||||
|     expect(removeFromArray([1, 2, 3, 4], 1, 2, 3, 4)).toEqual([]); | ||||
|   }); | ||||
|   test.skip('works with strings', () => { | ||||
|   test('works with strings', () => { | ||||
|     expect(removeFromArray(["hey", 2, 3, "ho"], "hey", 3)).toEqual([2, "ho"]); | ||||
|   }); | ||||
|   test.skip('only removes same type', () => { | ||||
|   test('only removes same type', () => { | ||||
|     expect(removeFromArray([1, 2, 3], "1", 3)).toEqual([1, 2]); | ||||
|   }); | ||||
| }); | ||||
|  |  | |||
|  | @ -1,5 +1,27 @@ | |||
| const sumAll = function() { | ||||
| const sumAll = function(num1, num2) { | ||||
|     let sum = 0; | ||||
|     let num1Type = typeof num1; | ||||
|     let num2Type = typeof num2; | ||||
| 
 | ||||
|     //Ensures number is not negative
 | ||||
|     if (num1 < 0 || num2 < 0) { | ||||
|         return "ERROR"; | ||||
|     //Ensures sum is a number
 | ||||
|     } else if (num1Type !== "number" || num2Type !== "number") { | ||||
|         return "ERROR"; | ||||
|     //If the second number is smaller than the first number
 | ||||
|     } else if (num2 < num1) { | ||||
|         for (let i = num2; i <= num1; i++) { | ||||
|             sum += parseInt(i); | ||||
|         } | ||||
|         return sum; | ||||
|     //If the first number is larger than the second number
 | ||||
|     } else { | ||||
|         for (let i = num1; i <= num2; i++) { | ||||
|             sum += parseInt(i); | ||||
|         } | ||||
|         return sum; | ||||
|     } | ||||
| }; | ||||
| 
 | ||||
| // Do not edit below this line
 | ||||
|  |  | |||
|  | @ -4,19 +4,19 @@ describe('sumAll', () => { | |||
|   test('sums numbers within the range', () => { | ||||
|     expect(sumAll(1, 4)).toEqual(10); | ||||
|   }); | ||||
|   test.skip('works with large numbers', () => { | ||||
|   test('works with large numbers', () => { | ||||
|     expect(sumAll(1, 4000)).toEqual(8002000); | ||||
|   }); | ||||
|   test.skip('works with larger number first', () => { | ||||
|   test('works with larger number first', () => { | ||||
|     expect(sumAll(123, 1)).toEqual(7626); | ||||
|   }); | ||||
|   test.skip('returns ERROR with negative numbers', () => { | ||||
|   test('returns ERROR with negative numbers', () => { | ||||
|     expect(sumAll(-10, 4)).toEqual('ERROR'); | ||||
|   }); | ||||
|   test.skip('returns ERROR with non-number parameters', () => { | ||||
|   test('returns ERROR with non-number parameters', () => { | ||||
|     expect(sumAll(10, "90")).toEqual('ERROR'); | ||||
|   }); | ||||
|   test.skip('returns ERROR with non-number parameters', () => { | ||||
|   test('returns ERROR with non-number parameters', () => { | ||||
|     expect(sumAll(10, [90, 1])).toEqual('ERROR'); | ||||
|   }); | ||||
| }); | ||||
|  |  | |||
|  | @ -1,5 +1,14 @@ | |||
| const leapYears = function() { | ||||
| 
 | ||||
| const leapYears = function(year) { | ||||
|     //if year is divisible by 100 && 400
 | ||||
|     //if year is divisible by 4
 | ||||
|     //else false
 | ||||
|     if (year % 100 === 0 && year % 400 === 0) { | ||||
|         return true; | ||||
|     } else if (year % 4 === 0 && year % 100 !== 0) { | ||||
|         return true; | ||||
|     } else { | ||||
|         return false; | ||||
|     } | ||||
| }; | ||||
| 
 | ||||
| // Do not edit below this line
 | ||||
|  |  | |||
|  | @ -4,19 +4,19 @@ describe('leapYears', () => { | |||
|   test('works with non century years', () => { | ||||
|     expect(leapYears(1996)).toBe(true); | ||||
|   }); | ||||
|   test.skip('works with non century years', () => { | ||||
|   test('works with non century years', () => { | ||||
|     expect(leapYears(1997)).toBe(false); | ||||
|   }); | ||||
|   test.skip('works with ridiculously futuristic non century years', () => { | ||||
|   test('works with ridiculously futuristic non century years', () => { | ||||
|     expect(leapYears(34992)).toBe(true); | ||||
|   }); | ||||
|   test.skip('works with century years', () => { | ||||
|   test('works with century years', () => { | ||||
|     expect(leapYears(1900)).toBe(false); | ||||
|   }); | ||||
|   test.skip('works with century years', () => { | ||||
|   test('works with century years', () => { | ||||
|     expect(leapYears(1600)).toBe(true); | ||||
|   }); | ||||
|   test.skip('works with century years', () => { | ||||
|   test('works with century years', () => { | ||||
|     expect(leapYears(700)).toBe(false); | ||||
|   }); | ||||
| }); | ||||
|  |  | |||
|  | @ -1,9 +1,15 @@ | |||
| const ftoc = function() { | ||||
| 
 | ||||
| const ftoc = function(fnum) { | ||||
|   //formula to convert f to c
 | ||||
|   let cnum = (fnum - 32) * 5 / 9; | ||||
|   //round to one decimal
 | ||||
|   return Math.round(cnum * 10) / 10; | ||||
| }; | ||||
| 
 | ||||
| const ctof = function() { | ||||
| 
 | ||||
| const ctof = function(cnum) { | ||||
|   //formula to convert c to f
 | ||||
|   let fnum = (cnum * 9/5) + 32; | ||||
|   //round to one decimal
 | ||||
|   return Math.round(fnum * 10) / 10; | ||||
| }; | ||||
| 
 | ||||
| // Do not edit below this line
 | ||||
|  |  | |||
|  | @ -4,22 +4,22 @@ describe('ftoc', () => { | |||
|   test('works', () => { | ||||
|     expect(ftoc(32)).toEqual(0); | ||||
|   }); | ||||
|   test.skip('rounds to 1 decimal', () => { | ||||
|   test('rounds to 1 decimal', () => { | ||||
|     expect(ftoc(100)).toEqual(37.8); | ||||
|   }); | ||||
|   test.skip('works with negatives', () => { | ||||
|   test('works with negatives', () => { | ||||
|     expect(ftoc(-100)).toEqual(-73.3); | ||||
|   }); | ||||
| }); | ||||
| 
 | ||||
| describe('ctof', () => { | ||||
|   test.skip('works', () => { | ||||
|   test('works', () => { | ||||
|     expect(ctof(0)).toEqual(32); | ||||
|   }); | ||||
|   test.skip('rounds to 1 decimal', () => { | ||||
|   test('rounds to 1 decimal', () => { | ||||
|     expect(ctof(73.2)).toEqual(163.8); | ||||
|   }); | ||||
|   test.skip('works with negatives', () => { | ||||
|   test('works with negatives', () => { | ||||
|     expect(ctof(-10)).toEqual(14); | ||||
|   }); | ||||
| }); | ||||
|  |  | |||
|  | @ -1,26 +1,65 @@ | |||
| const add = function() { | ||||
| 	 | ||||
| const add = function(num1, num2) { | ||||
|   let total = num1 + num2; | ||||
|   return total; | ||||
| }; | ||||
| 
 | ||||
| const subtract = function() { | ||||
| 	 | ||||
| const subtract = function(num1, num2) { | ||||
| 	let total = num1 - num2; | ||||
|   return total; | ||||
| }; | ||||
| 
 | ||||
| const sum = function() { | ||||
| const sum = function(numList) { | ||||
| 	  let total = 0; | ||||
| 
 | ||||
|     for (let i = 0; i < numList.length; i++) { | ||||
|         total += parseInt(numList[i]); | ||||
|     } | ||||
|      | ||||
|     return total; | ||||
| }; | ||||
| 
 | ||||
| const multiply = function() { | ||||
| const multiply = function(numList) { | ||||
|   let total = 1; | ||||
|    | ||||
|   for (let i = 0; i < numList.length; i++) { | ||||
|     total *= parseInt(numList[i]); | ||||
|   } | ||||
| 
 | ||||
|   return total; | ||||
| }; | ||||
| 
 | ||||
| const power = function() { | ||||
| <<<<<<< HEAD | ||||
| const power = function(num, power) { | ||||
| 	//empty variable for total
 | ||||
|   let total = 1; | ||||
|   //for loop to repeat num by power
 | ||||
|   for (let i = 0; i < power; i++) { | ||||
|     //multiply each num with empty variable 
 | ||||
|     total *= num; | ||||
|   } | ||||
|   return total;  | ||||
| ======= | ||||
| const power = function(num, pow) { | ||||
|   let total = 1; | ||||
| 
 | ||||
|   for (i=0; i<pow; i++) { | ||||
|       total *= num; | ||||
|   } | ||||
| 
 | ||||
|   return total; | ||||
| >>>>>>> 0c51ad1a2bf2379e6c83b344ac96ac708d94db1a | ||||
| }; | ||||
| 
 | ||||
| const factorial = function() { | ||||
| 	 | ||||
| }; | ||||
| const factorial = function(num) { | ||||
|   //empty variable for total
 | ||||
|   let total = 1; | ||||
|   //for loop to continue until num is reached
 | ||||
|   for (let i = 1; i <= num; i++) { | ||||
|     //multiply total with the i variable, which starts at 1, and repeats until num 
 | ||||
|     total *= i; | ||||
|   } | ||||
|   return total;  | ||||
|   }; | ||||
| 
 | ||||
| // Do not edit below this line
 | ||||
| module.exports = { | ||||
|  |  | |||
|  | @ -5,73 +5,73 @@ describe('add', () => { | |||
| 		expect(calculator.add(0,0)).toBe(0); | ||||
| 	}); | ||||
| 
 | ||||
| 	test.skip('adds 2 and 2', () => { | ||||
| 	test('adds 2 and 2', () => { | ||||
| 		expect(calculator.add(2,2)).toBe(4); | ||||
| 	}); | ||||
| 
 | ||||
| 	test.skip('adds positive numbers', () => { | ||||
| 	test('adds positive numbers', () => { | ||||
| 		expect(calculator.add(2,6)).toBe(8); | ||||
| 	}); | ||||
| }); | ||||
| 
 | ||||
| describe('subtract', () => { | ||||
| 	test.skip('subtracts numbers', () => { | ||||
| 	test('subtracts numbers', () => { | ||||
| 		expect(calculator.subtract(10,4)).toBe(6); | ||||
| 	}); | ||||
| }); | ||||
| 
 | ||||
| describe('sum', () => { | ||||
| 	test.skip('computes the sum of an empty array', () => { | ||||
| 	test('computes the sum of an empty array', () => { | ||||
| 		expect(calculator.sum([])).toBe(0); | ||||
| 	}); | ||||
| 
 | ||||
| 	test.skip('computes the sum of an array of one number', () => { | ||||
| 	test('computes the sum of an array of one number', () => { | ||||
| 		expect(calculator.sum([7])).toBe(7); | ||||
| 	}); | ||||
| 
 | ||||
| 	test.skip('computes the sum of an array of two numbers', () => { | ||||
| 	test('computes the sum of an array of two numbers', () => { | ||||
| 		expect(calculator.sum([7,11])).toBe(18); | ||||
| 	}); | ||||
| 
 | ||||
| 	test.skip('computes the sum of an array of many numbers', () => { | ||||
| 	test('computes the sum of an array of many numbers', () => { | ||||
| 		expect(calculator.sum([1,3,5,7,9])).toBe(25); | ||||
| 	}); | ||||
| }); | ||||
| 
 | ||||
| describe('multiply', () => { | ||||
| 	test.skip('multiplies two numbers', () => { | ||||
| 	test('multiplies two numbers', () => { | ||||
| 		expect(calculator.multiply([2,4])).toBe(8); | ||||
| 	}); | ||||
| 
 | ||||
| 	test.skip('multiplies several numbers', () => { | ||||
| 	test('multiplies several numbers', () => { | ||||
| 		expect(calculator.multiply([2,4,6,8,10,12,14])).toBe(645120); | ||||
| 	}); | ||||
| }); | ||||
| 
 | ||||
| describe('power', () => { | ||||
| 	test.skip('raises one number to the power of another number', () => { | ||||
| 	test('raises one number to the power of another number', () => { | ||||
| 		expect(calculator.power(4,3)).toBe(64); // 4 to third power is 64
 | ||||
| 	}); | ||||
| }); | ||||
| 
 | ||||
| describe('factorial', () => { | ||||
| 	test.skip('computes the factorial of 0', () => { | ||||
| 	test('computes the factorial of 0', () => { | ||||
| 		expect(calculator.factorial(0)).toBe(1); // 0! = 1
 | ||||
| 	}); | ||||
| 
 | ||||
| 	test.skip('computes the factorial of 1', () => { | ||||
| 	test('computes the factorial of 1', () => { | ||||
| 		expect(calculator.factorial(1)).toBe(1); | ||||
| 	}); | ||||
| 
 | ||||
| 	test.skip('computes the factorial of 2', () => { | ||||
| 	test('computes the factorial of 2', () => { | ||||
| 		expect(calculator.factorial(2)).toBe(2); | ||||
| 	}); | ||||
| 
 | ||||
| 	test.skip('computes the factorial of 5', () => { | ||||
| 	test('computes the factorial of 5', () => { | ||||
| 		expect(calculator.factorial(5)).toBe(120); | ||||
| 	}); | ||||
| 
 | ||||
| 	test.skip('computes the factorial of 10', () => { | ||||
| 	test('computes the factorial of 10', () => { | ||||
| 		expect(calculator.factorial(10)).toBe(3628800); | ||||
| 	}); | ||||
| }); | ||||
|  |  | |||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							|  | @ -14,11 +14,11 @@ | |||
|   }, | ||||
|   "homepage": "https://github.com/TheOdinProject/javascript-exercises#readme", | ||||
|   "devDependencies": { | ||||
|     "jest": "^26.6.3", | ||||
|     "jest-cli": "^26.6.3", | ||||
|     "eslint": "^7.26.0", | ||||
|     "eslint-config-airbnb-base": "^14.2.1", | ||||
|     "eslint-plugin-import": "^2.22.1" | ||||
|     "eslint-plugin-import": "^2.22.1", | ||||
|     "jest": "^26.6.3", | ||||
|     "jest-cli": "^26.6.3" | ||||
|   }, | ||||
|   "scripts": { | ||||
|     "test": "jest" | ||||
|  | @ -26,7 +26,7 @@ | |||
|   "eslintConfig": { | ||||
|     "root": true | ||||
|   }, | ||||
|    "jest": { | ||||
|   "jest": { | ||||
|     "testPathIgnorePatterns": [ | ||||
|       "generator-exercise/" | ||||
|     ] | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue