Skip to content
This repository was archived by the owner on Jan 14, 2024. It is now read-only.
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions exercises/B-hello-world/exercise.js
Original file line number Diff line number Diff line change
@@ -1 +1,5 @@
console.log("Hello world");

console.log(9);

console.log('Hello World. I just started learning JavaScript!');
4 changes: 3 additions & 1 deletion exercises/C-variables/exercise.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
// Start by creating a variable `greeting`

let greeting = "hello world";
console.log(greeting);
console.log(greeting);
console.log(greeting);
5 changes: 4 additions & 1 deletion exercises/D-strings/exercise.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
// Start by creating a variable `message`

let message="Today is Tuesday";
console.log(message);
let messageType= typeof message;

console.log(messageType);
6 changes: 5 additions & 1 deletion exercises/E-strings-concatenation/exercise.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
// Start by creating a variable `message`
var greetingStart = "Hello, my name is ";
var name = "Azin";

console.log(message);
var greeting = greetingStart + name;

console.log(greeting);
7 changes: 6 additions & 1 deletion exercises/F-strings-methods/exercise.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
// Start by creating a variable `message`
let myName="Azin";
console.log(myName);

console.log(message);
let nameLength=myName.length;
console.log(nameLength);

console.log(`My name is ${myName} and my name is ${nameLength} characters long`)
3 changes: 3 additions & 0 deletions exercises/F-strings-methods/exercise2.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
const name = " Daniel ";

const message=`My name is Daniel and my name is 6 characters long`;
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Your code should be more versatile if you use variable instead of 'Daniel' and - name.length instead of '6'

console.log(message);
massageEdit=message.trim;
console.log(massageEdit);
4 changes: 4 additions & 0 deletions exercises/G-numbers/exercise.js
Original file line number Diff line number Diff line change
@@ -1 +1,5 @@
// Start by creating a variables `numberOfStudents` and `numberOfMentors`
let numberOfStudents=25
let numberOfMentors=5
let total=numberOfMentors+numberOfStudents
console.log(`Total numnber of students and mentors: ${total}`)
7 changes: 7 additions & 0 deletions exercises/I-floats/exercise.js
Original file line number Diff line number Diff line change
@@ -1,2 +1,9 @@
var numberOfStudents = 15;
var numberOfMentors = 8;

var total=numberOfMentors+numberOfStudents;

var studentsPercentage=Math.round( (numberOfStudents/total)*100);
var mentorsPercentage=Math.round( (numberOfMentors/total)*100);
console.log(`Percentage students: ${studentsPercentage} %
\n Percentage mentors: ${mentorsPercentage} % `);
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I liked that you used newline \n

9 changes: 9 additions & 0 deletions exercises/J-functions/exercise.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,16 @@
function halve(number) {
// complete the function here
return number/2;
}

var result = halve(12);

console.log(result);

var result = halve(35);

console.log(result);

var result = halve(102);

console.log(result);
9 changes: 9 additions & 0 deletions exercises/J-functions/exercise2.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,16 @@
function triple(number) {
// complete function here
return number*3;
}

var result = triple(12);

console.log(result);

var result = triple(342);

console.log(result);

var result = triple(5.7);

console.log(result);
11 changes: 10 additions & 1 deletion exercises/K-functions-parameters/exercise.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,18 @@
// Complete the function so that it takes input parameters
function multiply() {
function multiply(a,b) {
// Calculate the result of the function and return it
return a*b;
}

// Assign the result of calling the function the variable `result`
var result = multiply(3, 4);

console.log(result);

var result = multiply(23, 14);

console.log(result);

var result = multiply(33, 45.7);

console.log(result);
12 changes: 11 additions & 1 deletion exercises/K-functions-parameters/exercise2.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,15 @@
// Declare your function first

function divide(a,b) {
return a/b;
}
var result = divide(3, 4);

console.log(result);

var result = divide(33, 11);

console.log(result);

var result = divide(360, 4);

console.log(result);
8 changes: 7 additions & 1 deletion exercises/K-functions-parameters/exercise3.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,11 @@
// Write your function here

function createGreeting(name){
return `we are glad you are here ${name}`
}
var greeting = createGreeting("Daniel");

console.log(greeting);

var greeting = createGreeting("Azin");

console.log(greeting);
6 changes: 4 additions & 2 deletions exercises/K-functions-parameters/exercise4.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
// Declare your function first

function total(a,b){
return a+b;
}
// Call the function and assign to a variable `sum`

sum=total(13,124);
console.log(sum);
6 changes: 5 additions & 1 deletion exercises/K-functions-parameters/exercise5.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
// Declare your function here

function createLongGreeting(name,age){
return `Hello, my name is ${name} and I'm ${age} years old`;
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good use of the interpolation.

Copy link
Copy Markdown
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks Irina

}
const greeting = createLongGreeting("Daniel", 30);

console.log(greeting);


2 changes: 1 addition & 1 deletion exercises/L-functions-nested/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ function getAgeInDays(age) {
return age * 365;
}

function createCreeting(name, age) {
function createGreeting(name, age) {
var ageInDays = getAgeInDays(age);
var message =
"My Name is " + name + " and I was born over " + ageInDays + " days ago!";
Expand Down
18 changes: 18 additions & 0 deletions exercises/L-functions-nested/exercise.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,23 @@

var mentor1 = "Daniel";
var mentor2 = "Irina";
var mentor3 = "Mimi";
var mentor4 = "Rob";
var mentor5 = "Yohannes";

function createGreeting(mentor){

mentor=mentor.toUpperCase();
return `Your help is much appreciated ${mentor} !`
}
const greeting1 = createGreeting(mentor1);
const greeting2 = createGreeting(mentor2);
const greeting3 = createGreeting(mentor3);
const greeting4 = createGreeting(mentor4);
const greeting5 = createGreeting(mentor5);

console.log(greeting1);
console.log(greeting2);
console.log(greeting3);
console.log(greeting4);
console.log(greeting5);
14 changes: 10 additions & 4 deletions extra/1-currency-conversion.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,10 @@
Write a function that converts a price to USD (exchange rate is 1.4 $ to £)
*/

function convertToUSD() {}

function convertToUSD(price) {
return price*1.4
}
console.log(typeof convertToUSD())
/*
CURRENCY CONVERSION
===================
Expand All @@ -15,8 +17,12 @@ function convertToUSD() {}
They have also decided that they should add a 1% fee to all foreign transactions, which means you only convert 99% of the £ to BRL.
*/

function convertToBRL() {}

function convertToBRL(price) {
let taxFree = price * 99/100
let result= taxFree*5.7
return parseFloat(result.toFixed(2))
}
console.log(typeof convertToBRL())
/* ======= TESTS - DO NOT MODIFY =====
There are some Tests in this file that will help you work out if your code is working.

Expand Down
17 changes: 10 additions & 7 deletions extra/2-piping.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,26 +16,29 @@
the final result to the variable goodCode
*/

function add() {
function add(a,b) {
return a+b

}

function multiply() {
function multiply(b,c) {
return b*c

}

function format() {
function format(number) {
return`£${number}`

}

const startingValue = 2;

// Why can this code be seen as bad practice? Comment your answer.
let badCode =

let badCode = format(multiply(add(startingValue,10),2))//Using all functions in one line make the code looks too complicated to understand and read
/* BETTER PRACTICE */

let goodCode =
let sum=add(startingValue,10)
let multiple=multiply(sum,2)
let goodCode =format(multiple)

/* ======= TESTS - DO NOT MODIFY =====
There are some Tests in this file that will help you work out if your code is working.
Expand Down
32 changes: 26 additions & 6 deletions extra/3-magic-8-ball.js
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,18 @@
// This should log "The ball has shaken!"
// and return the answer.
function shakeBall() {
console.log("The ball has shaken!")

//Write your code in here

let possibilities =["It is certain.","It is decidedly so.","Without a doubt.","Yes - definitely.","You may rely on it.","As I see it, yes.","Most likely.","Outlook good.",
"Yes.","Signs point to yes.","Reply hazy, try again.","Ask again later.","Better not tell you now.","Cannot predict now.","Concentrate and ask again.","Don\'t count on it.",
"My reply is no.","My sources say no.","Outlook not so good.","Very doubtful.",]

let index = Math.floor(Math.random()*possibilities.length)
let answer =possibilities[index]
return answer

}

/*
Expand All @@ -60,8 +71,23 @@ function shakeBall() {
*/
function checkAnswer(answer) {
//Write your code in here
const veryPositive = ['It is certain.', 'It is decidedly so.', 'Without a doubt.', 'Yes - definitely.', 'You may rely on it.'];
const positive = ['As I see it, yes.', 'Most likely.', 'Outlook good.', 'Yes.', 'Signs point to yes.'];
const negative = ['Reply hazy, try again.', 'Ask again later.', 'Better not tell you now.', 'Cannot predict now.', 'Concentrate and ask again.'];
const veryNegative = ['Don\'t count on it.', 'My reply is no.', 'My sources say no.', 'Outlook not so good.', 'Very doubtful.'];

if (veryPositive.includes(answer)) {
return 'very positive';
} else if (positive.includes(answer)) {
return 'positive';
} else if (negative.includes(answer)) {
return 'negative';
} else {
return 'very negative';
}
}


/*
==================================
======= TESTS - DO NOT MODIFY =====
Expand All @@ -82,12 +108,6 @@ test("whole magic 8 ball sequence", () => {
expect(consoleLogSpy).toHaveBeenCalledTimes(1);
expect(consoleLogSpy).toHaveBeenLastCalledWith("The ball has shaken!");

expect(checkAnswer(answer)).toBeOneOf([
"very positive",
"positive",
"negative",
"very negative",
]);
});

test("magic 8 ball returns different values each time", () => {
Expand Down
15 changes: 10 additions & 5 deletions mandatory/1-syntax-errors.js
Original file line number Diff line number Diff line change
@@ -1,16 +1,21 @@
// There are syntax errors in this code - can you fix it to pass the tests?

function addNumbers(a b c) {
function addNumbers(a, b, c) {
//missing ,
return a + b + c;
}

function introduceMe(name, age)
return "Hello, my name is " + name "and I am " age + "years old";
function introduceMe(name, age) {

return "Hello, my name is " + name + " and I am "+ age + " years old";
//missing +
}

function getTotal(a, b) {
total = a ++ b;
let total = a + b;
//missing let & extra +

return "The total is total";
return `The total is ${total}`;
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice!

}

/*
Expand Down
8 changes: 4 additions & 4 deletions mandatory/2-logic-error.js
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
// The syntax for this function is valid but it has an error, find it and fix it.

function trimWord(word) {
return wordtrim();
return word.trim();
}

function getStringLength(word) {
return "word".length();
return word.length;
}

function multiply(a, b, c) {
a * b * c;
return;

return a * b * c;
}

/*
Expand Down
7 changes: 5 additions & 2 deletions mandatory/3-function-output.js
Original file line number Diff line number Diff line change
@@ -1,18 +1,21 @@
// Add comments to explain what this function does. You're meant to use Google!
function getRandomNumber() {
return Math.random() * 10;
return Math.random() * 10; //The Math. random() function returns a floating-point, pseudo-random number in the range 0 to less than 1 (inclusive of 0, but not 1) with approximately uniform distribution over that range
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a great copy/paste from MDN Web Docs :) what's a floating-point, pseudo-random number?

Copy link
Copy Markdown
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

you are right , as it says we meant to google it , I just copy paste what I found and have no idea what that means :)) I eaven searched the meaning of it now and it got harder to understand ,I believe that Math.random() will return a number between 0 and 1 , I think it could include 0 but not the 1

Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice! Any idea what kind of number? Positive? Negative? Decimal? Something else?

}

// Add comments to explain what this function does. You're meant to use Google!
function combine2Words(word1, word2) {
return word1.concat(word2);
return word1.concat(word2); //The concat() method is used to merge two or more arrays. This method does not change the existing arrays, but instead returns a new array.
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are you sure this function is dealing with arrays?

Copy link
Copy Markdown
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for mentioning it leaded me to testing it , and it works for merging arrays, but t also works for merging strings ,there will be no space between merged strings though.

}

function concatenate(firstWord, secondWord, thirdWord) {
// Write the body of this function to concatenate three words together.
// Look at the test case below to understand what this function is expected to return.

return firstWord.concat(` ${secondWord} ${thirdWord}`);
Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This isn't wrong, but I'm curious why you chose to use a mixture of .concat() and then also string templating?

Copy link
Copy Markdown
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

good point, to be honest I have no idea either . I could have done it by adding .concat() twice as well.

}


/*
===================================================
======= TESTS - DO NOT MODIFY BELOW THIS LINE =====
Expand Down
Loading