30 Days Of JavaScript: Loops

Twitter Follow Author: Asabeneh Yetayeh
January, 2020
[<< Day 5](../05_Day_Arrays/05_day_arrays.md) | [Day 7 >>](../07_Day_Functions/07_day_functions.md) ![Day 5](../images/banners/day_1_6.png) - [📔 Day 6](#-day-6) - [Loops](#loops) - [for Loop](#for-loop) - [while loop](#while-loop) - [do while loop](#do-while-loop) - [for of loop](#for-of-loop) - [break](#break) - [continue](#continue) - [💻 Exercises:Day 6](#-exercisesday-6) - [Exercises: Level 1](#exercises-level-1) - [Exercises: Level 2](#exercises-level-2) - [Exercises: Level 3](#exercises-level-3) # 📔 Day 6 ## Loops Most of the activities we do in life are full of repetitions. Imagine if I ask you to print out from 0 to 100 using console.log(). To implement this simple task it may take you 2 to 5 minutes, such kind of tedious and repetitive task can be carried out using loop. If you prefer watching the videos, you can checkout the [video tutorials](https://www.youtube.com/channel/UCM4xOopkYiPwJqyKsSqL9mw) In programming languages to carry out repetitive task we use different kinds of loops. The following examples are the commonly used loops in JavaScript and other programming languages. ### for Loop ```js // For loop structure for(initialization, condition, increment/decrement){ // code goes here } ``` ```js for(let i = 0; i <= 5; i++){ console.log(i) } // 0 1 2 3 4 5 ``` ```js for(let i = 5; i >= 0; i--){ console.log(i) } // 5 4 3 2 1 0 ``` ```js for(let i = 0; i <= 5; i++){ console.log(`${i} * ${i} = ${i * i}`) } ``` ```sh 0 * 0 = 0 1 * 1 = 1 2 * 2 = 4 3 * 3 = 9 4 * 4 = 16 5 * 5 = 25 ``` ```js const countries = ['Finland', 'Sweden', 'Denmark', 'Norway', 'Iceland'] const newArr = [] for(let i = 0; i < countries.length; i++){ newArr.push(countries[i].toUpperCase()) } // ["FINLAND", "SWEDEN", "DENMARK", "NORWAY", "ICELAND"] ``` Adding all elements in the array ```js const numbers = [1, 2, 3, 4, 5] let sum = 0 for(let i = 0; i < numbers.length; i++){ sum = sum + numbers[i] // can be shorten, sum += numbers[i] } console.log(sum) // 15 ``` Creating a new array based on the existing array ```js const numbers = [1, 2, 3, 4, 5] const newArr = [] let sum = 0 for(let i = 0; i < numbers.length; i++){ newArr.push( numbers[i] ** 2) } console.log(newArr) // [1, 4, 9, 16, 25] ``` ```js const countries = ['Finland', 'Sweden', 'Norway', 'Denmark', 'Iceland'] const newArr = [] for(let i = 0; i < countries.length; i++){ newArr.push(countries[i].toUpperCase()) } console.log(newArr) // ["FINLAND", "SWEDEN", "NORWAY", "DENMARK", "ICELAND"] ``` ### while loop ```js let i = 0 while (i <= 5) { console.log(i) i++ } // 0 1 2 3 4 5 ``` ### do while loop ```js let i = 0 do { console.log(i) i++ } while (i <= 5) // 0 1 2 3 4 5 ``` ### for of loop We use for of loop for arrays. It is very hand way to iterate through an array if we are not interested in the index of each element in the array. ```js for (const element of arr) { // code goes here } ``` ```js const numbers = [1, 2, 3, 4, 5] for (const num of numbers) { console.log(num) } // 1 2 3 4 5 for (const num of numbers) { console.log(num * num) } // 1 4 9 16 25 // adding all the numbers in the array let sum = 0 for (const num of numbers) { sum = sum + num // can be also shorten like this, sum += num // after this we will use the shorter synthax(+=, -=, *=, /= etc) } console.log(sum) // 15 const webTechs = [ 'HTML', 'CSS', 'JavaScript', 'React', 'Redux', 'Node', 'MongoDB' ] for (const tech of webTechs) { console.log(tech.toUpperCase()) } // HTML CSS JAVASCRIPT REACT NODE MONGODB for (const tech of webTechs) { console.log(tech[0]) // get only the first letter of each element, H C J R N M } ``` ```js const countries = ['Finland', 'Sweden', 'Norway', 'Denmark', 'Iceland'] const newArr = [] for(const country of countries){ newArr.push(country.toUpperCase()) } console.log(newArr) // ["FINLAND", "SWEDEN", "NORWAY", "DENMARK", "ICELAND"] ``` ### break Break is used to interrupt a loop. ```js for(let i = 0; i <= 5; i++){ if(i == 3){ break } console.log(i) } // 0 1 2 ``` The above code stops if 3 found in the iteration process. ### continue We use the keyword *continue* to skip a certain iterations. ```js for(let i = 0; i <= 5; i++){ if(i == 3){ continue } console.log(i) } // 0 1 2 4 5 ``` 🌕 You are so brave, you made it to this far. Now, you have gained the power to automate repetitive and tedious tasks. You have just completed day 6 challenges and you are 6 steps a head in to your way to greatness. Now do some exercises for your brain and for your muscle. ## 💻 Exercises:Day 6 ### Exercises: Level 1 ```js const countries = [ 'Albania', 'Bolivia', 'Canada', 'Denmark', 'Ethiopia', 'Finland', 'Germany', 'Hungary', 'Ireland', 'Japan', 'Kenya' ] const webTechs = [ 'HTML', 'CSS', 'JavaScript', 'React', 'Redux', 'Node', 'MongoDB' ] const mernStack = ['MongoDB', 'Express', 'React', 'Node'] ``` 1. Iterate 0 to 10 using for loop, do the same using while and do while loop 2. Iterate 10 to 0 using for loop, do the same using while and do while loop 3. Iterate 0 to n using for loop 4. Write a loop that makes the following pattern using console.log(): ```js # ## ### #### ##### ###### ####### ``` 5. Use loop to print the following pattern: ```sh 0 x 0 = 0 1 x 1 = 1 2 x 2 = 4 3 x 3 = 9 4 x 4 = 16 5 x 5 = 25 6 x 6 = 36 7 x 7 = 49 8 x 8 = 64 9 x 9 = 81 10 x 10 = 100 ``` 6. Using loop print the following pattern ```sh i i^2 i^3 0 0 0 1 1 1 2 4 8 3 9 27 4 16 64 5 25 125 6 36 216 7 49 343 8 64 512 9 81 729 10 100 1000 ``` 7. Use for loop to iterate from 0 to 100 and print only even numbers 8. Use for loop to iterate from 0 to 100 and print only odd numbers 9. Use for loop to iterate from 0 to 100 and print only prime numbers 10. Use for loop to iterate from 0 to 100 and print the sum of all numbers. ```sh The sum of all numbers from 0 to 100 is 5050. ``` 11. Use for loop to iterate from 0 to 100 and print the sum of all evens and the sum of all odds. ```sh The sum of all evens from 0 to 100 is 2550. And the sum of all odds from 0 to 100 is 2500. ``` 12. Use for loop to iterate from 0 to 100 and print the sum of all evens and the sum of all odds. Print sum of evens and sum of odds as array ```sh [2550, 2500] ``` 13. Develop a small script which generate array of 5 random numbers 14. Develop a small script which generate array of 5 random numbers and the numbers must be unique 15. Develop a small script which generate a six characters random id: ```sh 5j2khz ``` ### Exercises: Level 2 1. Develop a small script which generate any number of characters random id: ```sh fe3jo1gl124g ``` ```sh xkqci4utda1lmbelpkm03rba ``` 1. Write a script which generates a random hexadecimal number. ```sh '#ee33df' ``` 1. Write a script which generates a random rgb color number. ```sh rgb(240,180,80) ``` 1. Using the above countries array, create the following new array. ```sh ["ALBANIA", "BOLIVIA", "CANADA", "DENMARK", "ETHIOPIA", "FINLAND", "GERMANY", "HUNGARY", "IRELAND", "JAPAN", "KENYA"] ``` 1. Using the above countries array, create an array for countries length'. ```sh [7, 7, 6, 7, 8, 7, 7, 7, 7, 5, 5] ``` 1. Use the countries array to create the following array of arrays: ```sh [ ['Albania', 'ALB', 7], ['Bolivia', 'BOL', 7], ['Canada', 'CAN', 6], ['Denmark', 'DEN', 7], ['Ethiopia', 'ETH', 8], ['Finland', 'FIN', 7], ['Germany', 'GER', 7], ['Hungary', 'HUN', 7], ['Ireland', 'IRE', 7], ['Iceland', 'ICE', 7], ['Japan', 'JAP', 5], ['Kenya', 'KEN', 5] ] ``` 2. In above countries array, check if there is a country or countries containing the word 'land'. If there are countries containing 'land', print it as array. If there is no country containing the word 'land', print 'All these countries are without land'. ```sh ['Finland','Ireland', 'Iceland'] ``` 3. In above countries array, check if there is a country or countries end with a substring 'ia'. If there are countries end with, print it as array. If there is no country containing the word 'ai', print 'These are countries ends without ia'. ```sh ['Albania', 'Bolivia','Ethiopia'] ``` 4. Using the above countries array, find the country containing the biggest number of characters. ```sh Ethiopia ``` 5. Using the above countries array, find the country containing only 5 characters. ```sh ['Japan', 'Kenya'] ``` 6. Find the longest word in the webTechs array 7. Use the webTechs array to create the following array of arrays: ```sh [["HTML", 4], ["CSS", 3],["JavaScript", 10],["React", 5],["Redux", 5],["Node", 4],["MongoDB", 7]] ``` 8. An application created using MongoDB, Express, React and Node is called a MERN stack app. Create the acronym MERN by using the array mernStack 9. Iterate through the array, ["HTML", "CSS", "JS", "React", "Redux", "Node", "Express", "MongoDB"] using a for loop or for of loop and print out the items. 10. This is a fruit array , ['banana', 'orange', 'mango', 'lemon'] reverse the order using loop without using a reverse method. 11. Print all the elements of array as shown below. ```js const fullStack = [ ['HTML', 'CSS', 'JS', 'React'], ['Node', 'Express', 'MongoDB'] ] ```` ```sh HTML CSS JS REACT NODE EXPRESS MONGODB ``` ### Exercises: Level 3 1. Copy countries array(Avoid mutation) 1. Arrays are mutable. Create a copy of array which does not modify the original. Sort the copied array and store in a variable sortedCountries 1. Sort the webTechs array and mernStack array 1. Extract all the countries contain the word 'land' from the [countries array](https://github.com/Asabeneh/30DaysOfJavaScript/tree/master/data/countries.js) and print it as array 1. Find the country containing the hightest number of characters in the [countries array](https://github.com/Asabeneh/30DaysOfJavaScript/tree/master/data/countries.js) 1. Extract all the countries contain the word 'land' from the [countries array](https://github.com/Asabeneh/30DaysOfJavaScript/tree/master/data/countries.js) and print it as array 1. Extract all the countries containing only four characters from the [countries array](https://github.com/Asabeneh/30DaysOfJavaScript/tree/master/data/countries.js) and print it as array 1. Extract all the countries containing two or more words from the [countries array](https://github.com/Asabeneh/30DaysOfJavaScript/tree/master/data/countries.js) and print it as array 1. Reverse the [countries array](https://github.com/Asabeneh/30DaysOfJavaScript/tree/master/data/countries.js) and capitalize each country and stored it as an array 🎉 CONGRATULATIONS ! 🎉 [<< Day 5](../05_Day_Arrays/05_day_arrays.md) | [Day 7 >>](../07_Day_Functions/07_day_functions.md)