Files

157 lines
3.0 KiB
Markdown
Raw Permalink Normal View History

---
id: 599d1566a02b571412643b84
title: エチオピア乗算
challengeType: 5
forumTopicId: 302257
dashedName: ethiopian-multiplication
---
# --description--
エチオピア乗算は、加算、倍増、および半減のみを使用して整数を乗算する方法です。
**方法:**
<ol>
<li>乗算対象の2つの数を取り、2つの列の上に書きます。</li>
<li>左側の列で、最後の数字を繰り返し2で割り、残りを捨て、値が <code>1</code> になるまで同じ列の最後に結果を書き込みます。</li>
<li>右側の列で、繰り返し最後の数字を2倍にして、結果を列の最後に書きます。 左側の列に <code>1</code> が表示されている行まで結果を入れ、その後停止します。</li>
<li>出来上がったテーブル見て、左側の列の値が偶数である行を削除します。</li>
<li>残っている右側の列の値を加算すると、元の2つの数を乗算した結果になります。</li>
</ol>
**例:** `17 × 34`
<pre>17 34
</pre>
最初の列の値を2で割ります。
<pre>17 34
8
4
2
1
</pre>
2列目を倍にします。
<pre>17 34
8 68
4 136
2 272
1 544
</pre>
最初の列が偶数の行の値を消します。
<pre>17 34
8 <strike>68</strike>
4 <strike>136</strike>
2 <strike>272</strike>
1 544
</pre>
右側の列の残りの数字を合計します。
<!-- markdownlint-disable MD003 -->
<pre>17 34
8 --
4 ---
2 ---
1 544
====
578
</pre>
<!-- markdownlint-enable MD003 -->
エチオピア乗算で `17``34` を掛けると `578` になります。
# --instructions--
タスクは、3つの名前付き関数/メソッド/プロシージャ/サブルーチンを定義することです。
<ol>
<li>整数を半分にする</li>
<li>整数を2倍にする</li>
<li>整数が偶数かどうかを示す</li>
</ol>
これらを使ってエチオピア乗算を行う関数を作ります。
<!-- markdownlint-disable MD046-->
# --hints--
`eth_mult` という関数です。
```js
assert(typeof eth_mult === 'function');
```
`eth_mult(17,34)``578` を返します。
```js
assert.equal(eth_mult(17, 34), 578);
```
`eth_mult(23,46)``1058` を返します。
```js
assert.equal(eth_mult(23, 46), 1058);
```
`eth_mult(12,27)``324` を返します。
```js
assert.equal(eth_mult(12, 27), 324);
```
`eth_mult(56,98)``5488` を返します。
```js
assert.equal(eth_mult(56, 98), 5488);
```
`eth_mult(63,74)``4662` を返します。
```js
assert.equal(eth_mult(63, 74), 4662);
```
# --seed--
## --seed-contents--
```js
function eth_mult(a, b) {
}
```
# --solutions--
```js
function eth_mult(a, b) {
let sum = 0; a = [a]; b = [b];
let half = a => a / 2,
double = a => a * 2,
is_even = a => a % 2 == 0;
while (a[0] !== 1) {
a.unshift(Math.floor(half(a[0])));
b.unshift(double(b[0]));
}
for (let i = a.length - 1; i > 0; i -= 1) {
if (!is_even(a[i])) {
sum += b[i];
}
}
return sum + b[0];
}
```