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

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

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

Q&A

解決済

1回答

1771閲覧

配列の足し算?がわかりません...

cunwe

総合スコア65

0グッド

0クリップ

投稿2020/04/28 05:05

https://atcoder.jp/contests/abc159/tasks/abc159_d

こちらの問題に関して質問がございます。解説動画では以下のようなコードを書いていました。

#include <bits/stdc++.h> #define rep(i,n) for (int i=0;i<(n);++i) using namespace std; typedef long long ll; ll choose2(ll n){ return n*(n-1)/2; } int main(){ int n; cin >> n; vector<int> a(n); rep(i,n) cin >> a[i]; rep(i,n) a[i]--; vector<int> cnt(n); rep(i,n) cnt[a[i]]++; ll tot=0; rep(i,n) { tot+=choose2(cnt[i]); } rep(i,n) { ll ans=tot; ans-=choose2(cnt[a[i]]); ans+=choose2(cnt[a[i]]-1); cout << ans << endl; } return 0; }

ここでrep(i,n) cnt[a[i]]++;というところが理解できません。これの2行下での操作は入力例1で言うとcnt[i]に3と2が入ると思うのですが、ということはcnt[a[i]]++で異なる数字の個数をそれぞれ計算できているということですか?例えば1 4 3 3 5 6 3 2 1 1という文字列があったらcnt[a[i]]++で3 1 3 1 1 1となり、それをcnt[i]が受け取り、choose2の関数に入れて計算しているのでしょうか?説明がわかりにくくて恐縮ですが、よろしくお願い致します・

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

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

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

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

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

guest

回答1

0

ベストアンサー

cnt[a[i]]++で異なる数字の個数をそれぞれ計算できているということですか?例えば1 4 3 3 5 6 3 2 1 1という文字列があったらcnt[a[i]]++で3 1 3 1 1 1となり、それをcnt[i]が受け取り、choose2の関数に入れて計算しているのでしょうか?

そのとおりです。repという、見慣れないマクロを使うと余計にわかりにくくなるので、展開したforループで書いたほうがいいでしょう。

投稿2020/04/28 05:08

maisumakun

総合スコア146018

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

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

maisumakun

2020/04/28 05:09

どの辺がわからなかったのか、掘り下げていただくことはできますか?
cunwe

2020/04/28 11:23

「cnt[a[i]]++」で異なる数字の個数をそれぞれ計算できているということですがその仕組みがよくわからないです...。「cnt[a[i]]++」だけでなぜ「異なる数字の個数をそれぞれ計算」という高度な?ことができているのか教えていただけますか?
maisumakun

2020/04/28 11:36

ループ1回毎に、cntの1要素へ1を足している、それだけです(1を足した回数=個数です)。何も「高度」なことはありません。
cunwe

2020/04/28 13:37

くどい質問で恐縮ですが「同じ数を見つけて」ということはどう行われているのでしょうか?
maisumakun

2020/04/28 13:41

「見つけて」などいません。3があったらcnt[3]に1を足す、5があればcnt[5]に1を足す、それだけです。
cunwe

2020/04/28 13:53

そういうことですか納得できました、ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問