ゴールデンウィークにTwitchでゲーム配信を始めた話|古いMacBook Pro・PS4・OBSで配信環境を作ってみた

Image
古いMacBook ProでもTwitch配信はできる?PS4・Switch2用にOBS配信環境を作ってみた ゴールデンウィークで時間があったので、以前から少し興味があったTwitchでのゲーム配信を始めてみました。 アカウントは うえはら000 。 主にストリートファイター6や、趣味で遊んでいるゲームを配信しながら、だらだら話すようなスタイルで配信しています。 この記事では、実際にTwitch配信を始めるまでに用意した機材、古いMacBook Proで配信してみた感想、配信を始めて分かったことをまとめます。 これから「家庭用ゲーム機で配信を始めてみたい」「古いMacでも配信できるのか知りたい」という人の参考になれば嬉しいです。 配信を始めたきっかけ もともと格闘ゲームは好きで、ストリートファイター4シリーズをそれなりに遊んでいました。 スーパーストリートファイターIV AE Ver.2012の頃は、家庭用でやり込みつつ、休みの日に新宿のタイトーステーションにも遊びに行っていました。 当時は、AE時代と比べて大幅に弱体化された後のユンを使っていて、一瞬だけグランドマスターに到達したことがあります。 とはいえ、グランドマスターだった期間は本当に一瞬で、実際にはマスター上位からグランドマスターに届くか届かないかくらいの位置にいることが多かったです。 ちなみに、強かった頃のユンはほとんど触っていません。スパ4AEの頃はまだライトゲーマーで、フェイロンを使っていました。 その後、Ver.2012でユン・ヤンが大きく弱体化されたのですが、対戦しているうちに「弱くなったとはいえ、まだかなり強くないか?」と思うようになり、試しに使い始めました。 使ってみると思った以上に自分に合っていたので、そのまま使い続けて、最終的にグランドマスターに届くところまでやり込みました。 その後、ウルトラストリートファイターIVが発表され、ユンに有利なシステム(赤セビ)やキャラ自体の強化も追加されました。ユンは再び強キャラの一角に戻ったのですが、当時は大学受験の時期と重なってしまい、ほとんどプレイできませんでした。 受験が終わった後も、大学生活や社会人生活がそれなりに忙しく、気づけばストリートファイターからはかなり離れていました。 他のゲームはちょくちょく遊んでいたものの、ストリートファイターを本格的...

Pythonで与えられた値が3の冪乗かを判定するプログラムの話。(LeetCode)

冪乗のお話。

3の冪乗かどうかを判定するプログラムを求められました。

326. Power of Three

整数型の値、nが引数として与えられた場合、それが3の冪乗かを判定し、冪乗ならばTrue、冪乗でなければFalseを返してください、っていう問題です。
なお、nの値には以下の制約が存在します。

-2^31 <= n <= 2^31 - 1

さて、どうしましょう?ってことでメモ。

解答

とりあえず解ける解答。

class Solution:
    def isPowerOfThree(self, n: int) -> bool:
        if n == 0:
            return False
        if n == 1:
            return True
        for i in range(31):
            if pow(3,i) == n:
                return True
        return False
# Runtime: 240 ms, faster than  5.15%  of  Python3  online submissions for  Power of Three.
# Memory Usage: 14.4 MB, less than  13.91%  of  Python3  online submissions for  Power of Three.

pow関数を使っています。

pow関数は引数に(基数、冪乗)を取っています。ここでの使い方は、31乗までを範囲としているため、for文で1~31までの値を回します。
pow(3,1) == n
pow(3,2) == n
.............
といったように3の1乗から31乗までを調べます。

ただし、31という値を意識しすぎる余り、かなり遅くなっています。
遅い理由としては、正しくない場合、31回も回すことになっているからです。

しかし、解けるだけでいいのであればこれでも良いことになります。

では、速度を意識してみましょう。

class Solution:
    def isPowerOfThree(self, n: int) -> bool:
        if n < 1:
            return False
        while n % 3 == 0:
            n /= 3
        return n == 1
#Runtime: 68 ms, faster than 87.60% of Python3 online submissions for Power of Three.
#Memory Usage: 14.3 MB, less than 46.96% of Python3 online submissions for Power of Three.

こちらの場合、while文で書き直しています。
そして、仮にnを3で割った時の値が0ではない場合、即判定が打ち切られます。
それゆえに最悪の場合に31回回すよりも高速化できています。

こんな感じ。最悪の場合に着目してアルゴリズムを設計する重要性を再確認しました。

今回はここまで。

Comments

Popular posts from this blog

【OSLog】How to log a Swift project

Principles of UX/UI Designでこんなことを学んでいるよ 第一週 User-centerd design①

Swiftで使うQueueのテンプレート