
3つ以上存在する要素がないか判定します
def isPossibleToSplit(self, nums: List[int]) -> bool:
c = defaultdict(int)
for i in nums:
c[i] += 1
if c[i] > 2:
return False
return True
としました。でも、足して3になたらFalseよりも
2のものにたそうとするときにFalseのほうが早いと思って
def isPossibleToSplit(self, nums: List[int]) -> bool:
c = defaultdict(int)
for i in nums:
if c[i] == 2:
return False
c[i] += 1
return True
としました。そしたらに個目のほうが遅くなりました。なんでですか??
ifをみる階数も同じだとおもいませんか?
No.2
- 回答日時:
なんでこんなC言語みたいなコードを書かないといけないかわかないんだけど、
C言語の場合、前者は
++ c[i] > 2
って分岐条件でかけるけど、
後者はc[i] ++ == 2とは書けないよね、って思う。
実際にはc[i]==2の際に、c[i]を足さずにreturnするから。
そう考えると、後者は前者みたいなシンプルな構造に最適化出来ないんじゃねえかな。
まあ本当に遅いのかどうかも知らんし、正直理由とかどうでもいい気がする。
後関係ないかもだけど、単にPythonは全てがオブジェクトだから、比較が他言語に比べて遅い可能性がある。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「指定されたキャストは有効で...
-
複数桁10進数の*桁目だけを抽出...
-
C言語での引数の省略方法
-
C言語初心者です、、、お助けく...
-
未解決の外部シンボル _printf...
-
#define _CRT_SECURE_NO_WARNIN...
-
(マルチスレッド)_beginthrea...
-
BMPを白黒画像にする方法。
-
【至急】プログラムにエラーが...
-
ラップ関数とはどんなものですか?
-
アスタリスクでダイヤ型を作る
-
C#の1~Xまでの数値を徐々に...
-
棒倒し法のプログラムについて...
-
DLLをGetProcAddress()で実行で...
-
C言語についてです。 void lcg(...
-
C言語でlookupのような関数って?
-
return 1L
-
単方向リストに適当な値を入れ...
-
エラー 添字が付けられた値が、...
-
C言語 巡回セールスマン問題 2-...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
複数桁10進数の*桁目だけを抽出...
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語 エラーの原因がわからな...
-
ラップ関数とはどんなものですか?
-
【C++】関数ポインタの使い方
-
if と配列の組み合わせ
-
(int *)の意味
-
ColorをRGBで指定する方法
-
未解決の外部シンボル _printf...
-
構造体の勉強中です 合計点の高...
-
商と剰余を同時に求める(C言語)
-
C言語で分からないところがあり...
-
式は定数値が必要です」という...
-
C言語での奇数の和
-
std::set<int> で、ある値が何...
-
課題でつまってます・・・
-
int16_t の _t は何?
-
比較回数と交換回数表示について
おすすめ情報