質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

2472閲覧

配列内で次の値に変化があった時の処理

barao

総合スコア18

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2018/09/12 06:03

編集2018/09/12 06:37

多次元配列で配列内の左の文字が同じ時だけ右の数値を足すという処理を考えてます。
多次元配列で配列(0番目は除く)[a,b]の内、aの値が同じ時だけbの値を足し、その計を配列に保管していくという処理を考えています。
途中までは上手く行くのですが最後が足せなくなります。
最初の'a'は必ず入るものとして考えています。

また、下記謎のエラーもでるので構文的に間違えているのかもよくわかりません。
Uncaught TypeError: Cannot read property '0' of undefined

もっと上手い書き方があるよという方、ご教示をお願いしたいです。

javascript

1let tajigen = [ 2 [ 'a' ], 3 [ 1,1 ], 4 [ 1,1 ], 5 [ 1,1 ], 6 [ 2,5 ], 7 [ 2,6 ], 8 [ 2,9 ], 9 [ 4,3 ], 10 [ 4,5 ], 11 [ 7,10 ], 12 [ 7,12 ], 13 ] ; 14 let hensu1=0;//比べる元を入れる用 15 let hensu1v=[];//1と2それぞれ足した値を入れる用 16 let syoukei=0;//左が同じ数値の時に足す用 17 hensu1 = tajigen[1][0]; 18 for(let n=1;n<tajigen.length-1;n++){ 19 let hensu2 = tajigen[n+1][0]; 20 if(n!==tajigen.length){ 21 if(hensu1===hensu2){ 22 syoukei += tajigen[n][1]; 23 }else{ 24 syoukei += tajigen[n][1]; 25 hensu1v.push(syoukei); 26   console.log('syoukei1:', syoukei); 27 syoukei = 0; 28 hensu1 = tajigen[n+1][0]; 29 } 30 }else{ 31 syoukei += tajigen[tajigen.length-1][1]; 32   console.log('syoukei2:', syoukei); 33 hensu1v.push(syoukei); 34 syoukei = 0; 35 } 36 } 37 console.log('hensu1v:', hensu1v);

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yukkuri

2018/09/12 06:10

私はjavascriptはほとんど知りませんが、まず調べましょう。「javascript エラー名」みたいな感じですると、情報が出てきます。
barao

2018/09/12 06:15

返信ありがとうございます。調べた結果よく分からないという結論なのです。値がないという意味らしいのですが値があるのに無いとはどういう事なのかが分かりません。ちなみにfor文の条件式を-1するとエラーは起きません。
x_x

2018/09/12 06:28

「左の文字」や「右の数値」は何を指していますか? 「同じ」というのは何と何が同じなのでしょうか? 「足す」というのも何に足すのかわかりません。
barao

2018/09/12 06:34

返信ありがとうございます。配列(0番目は除く)[a,b]の内、aの値が同じ時だけbの値を足し、その計を配列に保管していくという事なのですが、質問の回答になっていますでしょうか?説明が不足して申し訳ありません
x_x

2018/09/12 06:40

「同じ」というのは何と何が同じなのでしょうか?に答えていないと思います。「左の文字」というのがaですか? 数値のようですがいいのでしょうか? また、「右の数値」がbですか?
x_x

2018/09/12 06:43

提示コード中のtajigenの場合、どうなるのが理想なのでしょうか? また、tajigen自体を書き換えるのですか?
guest

回答2

0

ベストアンサー

多次元配列で配列内の...

言葉の意味としては2次元配列は多次元配列に含まれるものですが、
「2次元配列のみ考慮すればいい」のか、「3次元も考慮すべき」なのかで全く書くべきコードは異なります。
従って、お小言になって心苦しいですが質問者であればどちらかは書くべきでしょう。

コードを読む限り、2次元配列のみで良さそうなのでそう捉えつつ次へ進みます。

Uncaught TypeError: Cannot read property '0' of undefined

意訳: 君、配列から0のキーを取り出したいと言ってるけど、これは配列ではなくundefinedだから0キーなんて無いよ?

要するにtajigen[n+1][0]でしょうね。
配列は0スタート、length-1が終点になりますので、
for文内の最後のループでn+1のキーを取得しにいくと存在しないので、undefinedになるはずです。

...配列内の左の文字が同じ時だけ右の数値を足すという処理を考えてます。

日本語でおk良い感じになってますね、対応GJ。
質問文のコードを走らせての感想ですが、
配列の1要素目が「1同士を合計して3」「2同士を合計して20」「4同士を合計して8」を作りたいという意味なんですね。

こういう時はオブジェクトに変換したほうが良いと思います。

もっと上手い書き方があるよという方、ご教示をお願いしたいです。

配列は0から始まるものなので、
for文を扱う時はfor (i = 0; i < arr.length; i++)で始めましょう。
そうすることで例外を減らした綺麗なコードが書けるでしょう。

また、if文の中身は多くて2行、ガード節というelseを繋げずすぐに逃げる書き方があるので簡略化します。

JavaScript

1// 変数の宣言時はできるだけconstにすべき 2const tajigen = [ 3 ['a'], 4 [1, 1], 5 [1, 1], 6 [1, 1], 7 [2, 5], 8 [2, 6], 9 [2, 9], 10 [4, 3], 11 [4, 5], 12 [7, 10], 13 [7, 12], 14]; 15const result = {}; 16for (let i = 0; i < tajigen.length; i++) { 17 const key = tajigen[i][0]; 18 const val = tajigen[i][1]; 19 // aを捨てる書き方は色々あるが、今回は2個目の要素が存在しない場合は弾く事にする 20 if (typeof val === "undefined") continue; 21 if (!result[key]) result[key] = 0; 22 result[key] += val; 23} 24console.log(result); // {1: 3, 2: 20, 4: 8, 7: 22} 25 26// こうやって使う想定 27console.log(result[1]); // 3

投稿2018/09/12 06:48

編集2018/09/12 06:51
miyabi-sun

総合スコア21158

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

barao

2018/09/12 07:10

ありがとうございます。 分かりやすく、きれいなコードかつ、回答ですね。 いつかmiyab-sunのように簡潔なコードを書けるようにがんばります(*^^*)
guest

0

存在しない要素を参照しようとしてエラーになってます。
(n=10の時にtajigen[n+1][0]のところでtajigen[11][0]を参照しようとしてエラーが発生している)

投稿2018/09/12 06:10

madoka9393

総合スコア992

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

barao

2018/09/12 07:08

エラーの内容はなるほど、そういう事なのですね。回答ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問