ゴールデンウィークに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が発表され、ユンに有利なシステム(赤セビ)やキャラ自体の強化も追加されました。ユンは再び強キャラの一角に戻ったのですが、当時は大学受験の時期と重なってしまい、ほとんどプレイできませんでした。 受験が終わった後も、大学生活や社会人生活がそれなりに忙しく、気づけばストリートファイターからはかなり離れていました。 他のゲームはちょくちょく遊んでいたものの、ストリートファイターを本格的...

ゼロから始めるLeetCode Day58 「20. Valid Parentheses」

概要

海外ではエンジニアの面接においてコーディングテストというものが行われるらしく、多くの場合、特定の関数やクラスをお題に沿って実装するという物がメインである。

どうやら多くのエンジニアはその対策としてLeetCodeなるサイトで対策を行うようだ。

早い話が本場でも行われているようなコーディングテストに耐えうるようなアルゴリズム力を鍛えるサイトであり、海外のテックカンパニーでのキャリアを積みたい方にとっては避けては通れない道である。

と、仰々しく書いてみましたが、私は今のところそういった面接を受ける予定はありません。

ただ、ITエンジニアとして人並みのアルゴリズム力くらいは持っておいた方がいいだろうということで不定期に問題を解いてその時に考えたやり方をメモ的に書いていこうかと思います。

Leetcode

Python3で解いています。
Twitterやってます。

ゼロから始めるLeetCode 目次

前回
ゼロから始めるLeetCode Day57 「35. Search Insert Position」
次回
ゼロから始めるLeetCode Day59 「1221. Split a String in Balanced Strings」

Twitterやってます。

問題

20. Valid Parentheses
難易度はEasy。

問題としては文字 ‘(’, ‘)’, ‘{’, ‘}’, ‘[’ および ‘]’ だけを含む文字列sが与えられた場合、入力された文字列が有効かどうかを判断します。

入力文字列は、以下のような場合に有効です。

開いているカッコは、同じ種類のカッコで閉じなければなりません。
カッコは正しい順序で閉じなければなりません。
空の文字列も有効とみなされることに注意してください。

Input: “()”
Output: true

Input: “()[]{}”
Output: true

Input: “(]”
Output: false

Input: “([)]”
Output: false

Input: “{[]}”
Output: true

解法

例を見ればわかりますが、括弧の中で別に括弧が完結すればTrueになり得ますが、そうでない場合ならばFalseになる、といった風になります。

始まりと終わりをきっちり確認できれば良い、ということはスタックを使うと管理しやすいかなと思います。

例えば、Input: "{[]}"の場合で考えてみましょう。
for文を使ってcharへとsを代入し、前から読み取っていきます。
すると読み込まれる文字の順は'{','[',']','}'となります。

それをif文できちんと括弧が正しい順番で閉じられているかをチェックしなければなりません。

そのために、チェックするための括弧の集合を自前で用意してあげる必要があります。

ここではリストか辞書で管理するのが一般的かなと思います。

仮に括弧の要素をリストで管理した場合だと

open_str = ["[","{","("] close_str = ["]","}",")"]

こんな感じになり、
辞書で管理するなら
dict = {")":"(","]":"[","}":"{"}

こういった感じになるでしょう。
今回僕は辞書の方を使いました。

さて、ここまでくればあとはfor文で回した際にdictの中にchar要素が存在した場合、存在しなかった場合の処理を書けばよくなります。
仮に要素がdict.valuesの中に存在したときはどうすれば良いでしょう。
その場合は用意したstackへと追加してあげると良いでしょう。

stackの性質は皆さんご存知の通りLIFO(Last in first out)ですから、最後から取り出していくスタックは今回のようなケースの場合、都合が良いのです。

では、次にchardict.keysに存在する場合、そして最後にそれ以外の場合はどういった処理を行えば良いのか、ということになります。

その場合は新たに以下のような処理で書きました。

if stack == [] or dict[char] != stack.pop():
    return False

こうした場合、この内のどちらかに該当した場合False
を返します。
逆に言えば、これに該当しなければ処理は続きます。

そして、今まで書いたどの条件にも一致しない場合もFalseを返します。

これらをまとめて書いた内容が以下のようになります。

class Solution:
    def isValid(self, s: str) -> bool:
        stack = []
        dict = {")":"(","]":"[","}":"{"}
        for char in s:
            if char in dict.values():
                stack.append(char)
            elif char in dict.keys():
                if stack == [] or dict[char] != stack.pop():
                    return False
            else:
                return False
        return stack == []
# Runtime: 36 ms, faster than 30.47% of Python3 online submissions for Valid Parentheses.
# Memory Usage: 13.8 MB, less than 77.84% of Python3 online submissions for Valid Parentheses.

思ったより解法パートが長くなってしまいました・・・
もっとスパッと書いた方が読む側としては楽かもしれませんね。色々読み手の側も考えながら書いていきたいと思います。

話変わりますが最近アルゴリズムやデータ構造に限らずCSについて学んでいるのですが興味があるジャンルについて勉強するのは楽しいですね!

では今回はここまで。
お疲れ様でした。

Comments

Popular posts from this blog

【OSLog】How to log a Swift project

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

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