diff --git a/class-13-map-reduce/aziza-abdulrahman/map-exercise/README.md b/class-13-map-reduce/aziza-abdulrahman/map-exercise/README.md new file mode 100644 index 0000000..27e141b --- /dev/null +++ b/class-13-map-reduce/aziza-abdulrahman/map-exercise/README.md @@ -0,0 +1,38 @@ +## Instructions For MAP Exercises + + +1) Write a function capitalize that takes a string and uses .map to return the same string in all caps. + +Example +``` +capitalize('whoop') // => 'WHOOP' +capitalize('oh hey gurl') // => "OH HEY GURL" +``` +``` +const capitalize = function(string){ + // code code code! +} +``` + +2) Now write a new function called swapCase that takes a string of words and uses .map and your newly written capitalize() function to return a string where every other word is in all caps. +Hint: look up Array.prototype.map on MDN and see what arguments the .map callback can take. + +example +``` +swapCase('hey gurl, lets javascript together sometime') // => "HEY gurl, LETS javascript TOGETHER sometime" +``` +``` +const swapCase = function(string){ + // Codeeeee +} +``` +3) Write a function shiftLetters that takes a string and uses .map to return an encoded string with each letter shifted down the alphabet by one. Hint: Use Look up the JS functions String.fromCharCode() and String.charCodeAt() and see if you can use Ascii code to accomplish this. + +``` +shiftLetters('hello') // => 'ifmmp' +shiftLetters('abcxyz') // => "bcdyz{" + +const shiftLetters = function(string){ + // code! +} +``` \ No newline at end of file diff --git a/class-13-map-reduce/aziza-abdulrahman/map-exercise/index.js b/class-13-map-reduce/aziza-abdulrahman/map-exercise/index.js new file mode 100644 index 0000000..9d42b32 --- /dev/null +++ b/class-13-map-reduce/aziza-abdulrahman/map-exercise/index.js @@ -0,0 +1,32 @@ +// Question 1: +let names = ['Ali', 'Atta', 'Alex', 'John']; +const capitalize = names.map(name => name.toUpperCase()); +console.log(capitalize); + +//Question 2: +let str = 'hey girl, lets javascript together sometime'; +function swapCase (str) { +let strSplited = str.split(" "); +let test= [] +for (let i=0; i < strSplited.length; i++){ +if (i %2 === 0){ +test[i] =strSplited[i].toUpperCase(); +}else{ +test[i] = strSplited[i] +} +} +return test.join(" "); +} +let testfunc =swapCase (str); +console.log(testfunc); + + + +// Question 3: +let str = 'hello'; +str = str.replace(/[a-z]/gi, function(char) { +char = String.fromCharCode(char.charCodeAt(0)+1); +if (char=='{' || char=='[') char = 'a'; +return char; +}); +console.log(str); diff --git a/class-13-map-reduce/aziza-abdulrahman/map-reduce/README.md b/class-13-map-reduce/aziza-abdulrahman/map-reduce/README.md new file mode 100644 index 0000000..11878aa --- /dev/null +++ b/class-13-map-reduce/aziza-abdulrahman/map-reduce/README.md @@ -0,0 +1,65 @@ +## Get Sum of People's Budget + +Create the function that takes an array with objects and returns the sum of people's budgets. + +### Examples + + getBudgets([ + { name: "John", age: 21, budget: 23000 }, + { name: "Steve", age: 32, budget: 40000 }, + { name: "Martin", age: 16, budget: 2700 } + ]) ➞ 65700 + + getBudgets([ + { name: "John", age: 21, budget: 29000 }, + { name: "Steve", age: 32, budget: 32000 }, + { name: "Martin", age: 16, budget: 1600 } + ]) ➞ 62600 + + +## Instructions For Reduce and Map Exercises + +1) Write a function that takes a string and returns an object representing the character count for each letter. Use .reduce to build this object. + +Example +``` +countLetters('abbcccddddeeeee') // => {a:1, b:2, c:3, d:4, e:5} + +const countLetters = function(string){ + // your code here +}; +``` + +2) Write a function that takes a string and a target, and returns true or false if the target is present in the string. Use .reduce to accomplish this. + +Example +``` +isPresent('abcd', 'b') // => true +isPresent('efghi', 'a') // => false + +const isPresent = function(string, target) { + // your code +} +``` + +### PARTY WITH MAP AND REDUCE *AT THE SAME TIME* + +1) Write a function decode that will take a string of number sets and decode it using the following rules: +When each digit of each set of numbers is added together, the resulting sum is the ascii code for a single letter. +Convert each set of numbers into a letter and discover the secret message! +Try using map and reduce together to accomplish this task. +Example +``` +decode("361581732726247521644353 4161492813593986955 84654117917337166147521") // => "abc" +decode("584131398786538461382741 444521974525439455955 71415168525426614834414214 353238892594759181769 48955328774167683152 77672648114592331981342373 5136831421236 83269359618185726749 2554892676446686256 959958531366848121621517 4275965243664397923577 616142753591841179359 121266483532393851149467 17949678591875681") +// => "secret-message" + +const decode = function(string){ + // CODE PARTY +} +``` +Once you successfully write a decoding function, use it to decode this secret message! + +``` +"444689936146563731 2452966188592191874 52634311978613959924676311 4874232339 491973615889195397613151 64491375479568464397 2799868298847212752434 9464245911 84529438455334236247245 8131257451645317232949247 26471594451453281675411332 6631592725297745964837 616698332453173937881461 3311783543427862468268 385418321228899775431 4659867 73395213225525916984356 833792195426925124155181841 123388893 6941777837193213644325351 11353488912476869536954 61173937137292328237388335 5344692 452956158 31937616696951768494 584842118999165552436 8832121577139589884 15282516522883423742885 14713349724 6919979438697694 2252585676244745856486 5617683424485959291 547443594 2678324174797795449925 43753791352187862731151912 6875665565836721939262 35482977 84421878934473534291995 798457553821668942312 11114498238219156246883553 3599955 8831995953696776 8138759916933117676486 2388776737768787 37232647683297835458183 11318659392964788174775 683293746169875551252354 741545327395636643318531 38447974824822841161273 88768222547689886222 6345677462396774359 4942661761 1354569165 2553653936124138282 851786784517417366411515 42279319649497959785 5523951771 45941761289678527316294 37776454913244819275691 436669892715419465494342 682264111527 734681268219555989841131 882641896825571288724 382545666 12133138432672285179566156291 83644842221351483476411355532 9589336353993598224 184537669759184472427331 41851326945453796784 525783591 173773335961894524914465 47516715963756294236321 7296569497726217615 79487235 4931878519724923131437 31214731844284735237658435 1378458823933518466122 1241955123792435126557994 347427652476673662454 55596877477154112241923 9789414554758712319821 86228624276917113671233411 89659521 1352796469161477381192 69483824148396716861472 4766533634762298963245 5155973593459278561 1784478259974148659431 29583142566714785218623 244371427148584159487652 871836193187759591363 247956" +``` \ No newline at end of file diff --git a/class-13-map-reduce/aziza-abdulrahman/map-reduce/index.js b/class-13-map-reduce/aziza-abdulrahman/map-reduce/index.js new file mode 100644 index 0000000..440b711 --- /dev/null +++ b/class-13-map-reduce/aziza-abdulrahman/map-reduce/index.js @@ -0,0 +1,26 @@ +//Question 1: +let getBudgets = [ +{ name: "John", age: 21, budget: 23000 }, +{ name: "Steve", age: 32, budget: 40000 }, +{ name: "Martin", age: 16, budget: 2700 } +]; +let result = getBudgets.reduce((acc, getBudget)=> acc + getBudget.budget, 0) +console.log(result) + + + +//Question 2: +let countLetters = str => { +return str.split('').reduce((total, letter) => { +total[letter] ? total[letter]++ : total[letter] = 1; +return total; +}, {}); +}; +countLetters("abbcccddddeeeee"); + +//Question 3: +function decode(str) { +return str.split(" ").map(item => [...item].reduce((ascii,x) => ascii + Number(x), 0)).map(ascii => String.fromCharCode(ascii)).join("") +} +decode("361581732726247521644353 4161492813593986955 84654117917337166147521") +decode("584131398786538461382741 444521974525439455955 71415168525426614834414214 353238892594759181769 48955328774167683152 77672648114592331981342373 5136831421236 83269359618185726749 2554892676446686256 959958531366848121621517 4275965243664397923577 616142753591841179359 121266483532393851149467 17949678591875681")