Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Done all tasks #17

Open
wants to merge 8 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 6 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
47 changes: 47 additions & 0 deletions Exercises.ru.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
# Упражнения

## Итерирование циклами

Руализуйте функцию `sum(...args)`, которая суммирует все свои аргументы, пятью
разными способами. Примеры вызовов с результатами:
```js
const a = sum(1, 2, 3) // a === 6
const b = sum(0) // b === 0
const c = sum() // c === 0
const d = sum(1, -1, 1) // d === 1
const e = sum(10, -1, -1, -1) // e === 7
```

1. Цикл `for`
2. Цикл `for..of`
3. Цикл `while`
4. Цикл `do..while`
5. Метод `Array.prototype.reduce()`

## Итерирование по двумерному массиву

6. Найдите максимальный элемент в двумерном массиве
```js
const m = max([[1, 2, 3], [4, 5, 6], [7, 8, 9]]);
console.log(m); // 9
```

## Итерирование объектов-справочников

7. При помощи цикла `for..in` перебрать объект-справочник с датами рождения и
смерти людей и вернуть справочник с продолжительностью их жизни. Например:
```js
const persons = {
lenin: { born: 1870, died: 1924 },
mao: { born: 1893, died: 1976 },
gandhi: { born: 1869, died: 1948 },
hirohito: { born: 1901, died: 1989 },
};
console.log(ages(persons));
// {
// lenin: 54,
// mao: 83,
// gandhi: 79,
// hirohito: 88,
// }
```
8 changes: 5 additions & 3 deletions Exercises/1-for.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
'use strict';

const sum = (...args) => {
// Use for loop and accumulator variable
// to calculate sum of all given arguments
// For example sum(1, 2, 3) should return 6
let sum = 0;
for (let i = 0; i < args.length; i++) {
sum += args[i];
}
return sum;
};

module.exports = { sum };
6 changes: 3 additions & 3 deletions Exercises/2-for-of.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
'use strict';

const sum = (...args) => {
// Use for..of loop and accumulator variable
// to calculate sum of all given arguments
// For example sum(1, 2, 3) should return 6
let sum = 0;
for (const i of args) sum += i;
Copy link
Member

Choose a reason for hiding this comment

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

i is not a good naming for array element, it means index in array but here is i isn't an index

return sum;
};

module.exports = { sum };
10 changes: 7 additions & 3 deletions Exercises/3-while.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,13 @@
'use strict';

const sum = (...args) => {
// Use while loop and accumulator variable
// to calculate sum of all given arguments
// For example sum(1, 2, 3) should return 6
let sum = 0;
let i = 0;
while (i < args.length) {
sum += args[i];
i++;
}
return sum;
};

module.exports = { sum };
12 changes: 9 additions & 3 deletions Exercises/4-do-while.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,15 @@
'use strict';

const sum = (...args) => {
// Use do..while loop and accumulator variable
// to calculate sum of all given arguments
// For example sum(1, 2, 3) should return 6
if (args.length < 1) return 0;
let sum = 0;
let i = 0;
Copy link
Member

Choose a reason for hiding this comment

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

Having counter and not using pop/shift is much better for performance 👍

do {
sum += args[i];
i++;
}
while (i < args.length);
Copy link
Member

Choose a reason for hiding this comment

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

Better put it in a single line: } while (i < args.length);

return sum;
};

module.exports = { sum };
5 changes: 1 addition & 4 deletions Exercises/5-reduce.js
Original file line number Diff line number Diff line change
@@ -1,8 +1,5 @@
'use strict';

const sum = (...args) => 0;
// Use Array.prototype.reduce method
// to calculate sum of all given arguments
// For example sum(1, 2, 3) should return 6
const sum = (...args) => args.reduce((result, val) => result + val, 0);

module.exports = { sum };
15 changes: 15 additions & 0 deletions Exercises/6-matrix.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
'use strict';

const max = matrix => {
let max = 0;
Copy link
Member

Choose a reason for hiding this comment

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

You can name variable as a function but it will be better to use different name.

for (let i = 0; i < matrix.length; i++) {
for (let j = 0; j < matrix[i].length; j++) {
//max = max < matrix[i][j] ? matrix[i][j] : max;
if (max < matrix[i][j]) max = matrix[i][j];
Copy link
Member

Choose a reason for hiding this comment

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

Expression matrix[i][j] repeated twice, and we have additional matrix[i] in line 6. See my solution to optimize code.

}
}
return max;
};


module.exports = { max };
13 changes: 13 additions & 0 deletions Exercises/6-matrix.test
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
({
name: 'max',
length: [220, 300],
cases: [
[[[10]], 10],
[[[1, 2], [3, 4], [5, 6]], 6],
[[[-1, 1], [2, -1], [-1, 0]], 2],
],
test: max => {
const src = max.toString();
if (!src.includes('for (')) throw new Error('Use for loop');
}
})
11 changes: 11 additions & 0 deletions Exercises/7-ages.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
'use strict';

const ages = persons => {
const ages = {};
Copy link
Member

Choose a reason for hiding this comment

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

Use different variable name

for (const element in persons) {
ages[element] = persons[element]['died'] - persons[element]['born'];
Copy link
Member

Choose a reason for hiding this comment

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

Suggested change
ages[element] = persons[element]['died'] - persons[element]['born'];
const person = persons[element];
ages[element] = person.died - persons.born;

}
return ages;
};

module.exports = { ages };
24 changes: 24 additions & 0 deletions Exercises/7-ages.test
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
({
name: 'ages',
length: [150, 190],
cases: [
[
{
lenin: { born: 1870, died: 1924 },
mao: { born: 1893, died: 1976 },
gandhi: { born: 1869, died: 1948 },
hirohito: { born: 1901, died: 1989 },
}, {
lenin: 54,
mao: 83,
gandhi: 79,
hirohito: 88,
}
]
],
test: ages => {
const src = ages.toString();
if (!src.includes('for (')) throw new Error('Use for..in loop');
if (!src.includes(' in ')) throw new Error('Use for..in loop');
}
})
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Different implementation of iterations as a code abstraction

[![Массивы, объекты, классы, прототипы](https://img.youtube.com/vi/VBMGnAPfmsY/0.jpg)](https://www.youtube.com/watch?v=/VBMGnAPfmsY)
[![Массивы, объекты, классы, прототипы](https://img.youtube.com/vi/VBMGnAPfmsY/0.jpg)](https://www.youtube.com/watch?v=VBMGnAPfmsY)
[![Итерирование, циклы и итераторы](https://img.youtube.com/vi/lq3b5_UGJas/0.jpg)](https://www.youtube.com/watch?v=lq3b5_UGJas)
15 changes: 15 additions & 0 deletions Solutions/6-matrix.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
'use strict';

const max = matrix => {
let value = matrix[0][0];
for (let i = 0; i < matrix.length; i++) {
const row = matrix[i];
for (let j = 0; j < row.length; j++) {
const cell = row[j];
if (value < cell) value = cell;
}
}
return value;
};

module.exports = { max };
12 changes: 12 additions & 0 deletions Solutions/7-ages.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
'use strict';

const ages = persons => {
const data = {};
for (const name in persons) {
const person = persons[name];
data[name] = person.died - person.born;
}
return data;
};

module.exports = { ages };