国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

ホームページ バックエンド開発 Golang Code ay n Golang の出現(xiàn): ページの注文

Code ay n Golang の出現(xiàn): ページの注文

Dec 28, 2024 am 07:33 AM

導(dǎo)入

コードの出現(xiàn)から 5 日目ですが、今日はページの順序付けという興味深い問題があります。この問題と、私がどのようにそれに取り組んだのかを見ていきましょう。冷靜に考えれば非常に単純な問題ですが、そうでないとマップ、リスト、インデックスが混亂してしまいます。

ここ GitHub で私のソリューションをチェックできます。

Advent of Code ay n Golang: Ordering Pages ミスター?ディストラクティブ / コードの出現(xiàn)

コードの到來

入力

5 日目の入力には 2 つのセクションがあります。最初のセクションでは、ページの順序付けのルール、具體的にはどのページをどのページの前に置くかを定義し、2 番目のセクションには実際のページの順序が含まれます。

47|53
97|13
97|61
97|47
75|29
61|13
75|53
29|13
97|29
53|29
61|53
97|53
61|29
47|13
75|47
97|75
47|61
75|61
47|29
75|13
53|13

75,47,61,53,29
97,61,53,29,13
75,29,13
75,97,47,61,53
61,13,29
97,13,75,29,47

最初のセクションにはマッピングされたルールがあり、もう 1 つのセクションにはページの順序があり、各行は処理する実際のデータとしてのクエリまたはページのリストです。パート 1 と 2 の処理で使用する必要があります。

読書セクション

したがって、これらのセクションを解析し、アクセスしやすいデータ構(gòu)造で読み取る必要があります。

そのための 1 つの方法は次のとおりです

  • 2 つのセクションからなるリスト

  • 最初のセクションはリストになります

    • リストは 2 つの整數(shù)を保持するための整數(shù)のリスト、つまりルール用です
  • 2 番目のセクションはリストになります

    • リストはページリストを保持する整數(shù)のリストになります

したがって、データ構(gòu)造は整數(shù)のリストのリストのリストのようになります。

func ReadFileSections(path string) [][][]int {

    fileBytes := ReadFileBytes(path)
    lines := []string{}
    separator := []byte("\n\n")
    for _, line := range bytes.Split(fileBytes, separator) {
        if string(line) != "" {
            lines = append(lines, string(line))
        }
    }

    sections := [][][]int{}
    for i, section := range lines {
        nums := [][]int{}
        lineStrs := strings.Split(section, "\n")
        separator := ","
        if i == 0 {
            separator = "|"
        }
        for _, lineStr := range lineStrs {
            if lineStr == "" {
                continue
            }
            numL := []int{}
            for _, numStr := range strings.Split(lineStr, separator) {
                num, _ := strconv.Atoi(numStr)
                numL = append(numL, num)
            }
            nums = append(nums, numL)
        }
        sections = append(sections, nums)
    }
    return sections
}

ReadFileSections と呼ばれる上記の関數(shù)は、入力ファイルへのパスを受け取り、説明したように整數(shù)のリストのスライス/配列を返します。まずファイルを読み取り、バイトをセクションの區(qū)切りとなる 2 つの改行文字に分割します。行を文字列のリストとして保存します。最初の行にはルール行が含まれ、2 番目の行にはページ リスト行が含まれます。

次に、セクションを反復(fù)処理し、それぞれの區(qū)切り文字を使用してセクションの個々の行を個別に分割します。つまり、 |最初のセクションには (空白) が 2 番目のセクションに使用されます。各行を解析して整數(shù)のリストを取得し、それらをそれぞれのセクションに追加します。

これで、問題の処理に役立つルールとページの構(gòu)築に使用できるデータが得られました。

ルールの構(gòu)築

ここで、アクセスしやすいようにルール リストを処理する必要があります。特定のページの後に表示されるページ番號を取得する必要があるため、整數(shù)のリストを持つ整數(shù)のマップを使用します。キーは次のとおりです。最初の番號と値の 1 つは 2 番目の番號 (ページ順で後に表示される番號) になります。

func ConstructRules(rulesList [][]int) map[int][]int {
    rules := make(map[int][]int)
    for _, rule := range rulesList {
        rules[rule[0]] = append(rules[rule[0]], rule[1])
    }
    return rules
}

単純に整數(shù)のリストを反復(fù)処理し、リスト內(nèi)の最初の要素をキーとして、値を 2 番目の要素としてマップします。これにより、次のことが視覚化されます。

FROM

[][]int

[
    [47,53]
    [97,13]
    [97,61]
]

TO

map[int][]int
{
    47: [53]
    97: [13,61]
}

それで、ルールを整數(shù)と整數(shù)のマップとして作成しました。

インデックスの構(gòu)築

ここで、最初と 2 番目の部分を簡単にするために、ページ リストに表示されるインデックスを使用して、ルール セクションの各番號のマップを作成する必要があります。

そこで、整數(shù)と整數(shù)のマップであるルールを反復(fù)処理し、ルールから一意の整數(shù)リストを作成するのに役立つ整數(shù)のマップを作成します。

ルールから整數(shù)のリストを取得したら、すべての數(shù)値を反復(fù)処理し、ページの各行で、どのインデックスが表示されるかを確認(rèn)して、整數(shù) (インデックス) のリストを作成します。

そこで、ページの行にあるすべての數(shù)値を反復(fù)処理します。ページのリストでその數(shù)値が見つかった場合はインデックスを追加しますが、見つからなかった場合は -1 を追加します。したがって、各行について次のようにします。次のようにその番號にインデックスを追加する必要があります:

47|53
97|13
97|61
97|47
75|29
61|13
75|53
29|13
97|29
53|29
61|53
97|53
61|29
47|13
75|47
97|75
47|61
75|61
47|29
75|13
53|13

75,47,61,53,29
97,61,53,29,13
75,29,13
75,97,47,61,53
61,13,29
97,13,75,29,47

上記の例では、參照として 75 を取得し、ページ番號の各リストのインデックスを取得し、75 が出現(xiàn)するインデックスのリストを取得します。

これは次の関數(shù)で実行できます:

func ReadFileSections(path string) [][][]int {

    fileBytes := ReadFileBytes(path)
    lines := []string{}
    separator := []byte("\n\n")
    for _, line := range bytes.Split(fileBytes, separator) {
        if string(line) != "" {
            lines = append(lines, string(line))
        }
    }

    sections := [][][]int{}
    for i, section := range lines {
        nums := [][]int{}
        lineStrs := strings.Split(section, "\n")
        separator := ","
        if i == 0 {
            separator = "|"
        }
        for _, lineStr := range lineStrs {
            if lineStr == "" {
                continue
            }
            numL := []int{}
            for _, numStr := range strings.Split(lineStr, separator) {
                num, _ := strconv.Atoi(numStr)
                numL = append(numL, num)
            }
            nums = append(nums, numL)
        }
        sections = append(sections, nums)
    }
    return sections
}

これで、ルールに基づいて各ページ番號リストにインデックスがマッピングされました。

パート 1

パート 1 では、各ページ更新 (行) を反復(fù)する必要があります。次に、ページ番號がルールに従っているかどうかを確認(rèn)する必要があります。各番號はルールに従っている必要があります。これは、番號が特定の番號の後であるが、ルールでは前にあるべきであると規(guī)定されている場合、その更新でページ番號付けルールに違反しているため、それを正しい順序のページと見なすことができず、中央のページを追加する必要があることを意味します。パート 1 の回答として正しく順序付けされた各更新の番號。

これを行うには、各ページ更新を反復(fù)し、次にそのページ更新の各數(shù)値を反復(fù)する必要があります。その數(shù)値 (現(xiàn)在の數(shù)値と呼ぶことにします) に関連付けられたすべてのルールを取得します。整數(shù)のリストを含む整數(shù)のマップ。ここで、現(xiàn)在いる番號がそのルールの番號より前であるかどうかを確認(rèn)する必要があります。そこで、作成した數(shù)値インデックス (整數(shù)のリストをインデックスとして持つ數(shù)値のマップ) を使用して、現(xiàn)在の數(shù)値のインデックスを確認(rèn)します。したがって、現(xiàn)在の番號をマップのキーとして使用し、リスト內(nèi)のインデックスを現(xiàn)在いる行/ページの更新數(shù)としてマップのインデックスのリストを取得します。

現(xiàn)在の番號のインデックスを取得したら、そのルール內(nèi)のすべての番號である 2 番目の番號についても同じものを取得します。また、ルール內(nèi)のその番號がそのページ行/更新に存在するかどうか、つまり、 -1 ではなく、その場合は、同様にそのインデックスを取得し、ルールに従って現(xiàn)在の番號の後に出現(xiàn)するかどうかを確認(rèn)します。したがって、番號がルールに違反している場合は、ページの更新を正しくないものとしてマークする必要があります。注文します。

そのページ更新のインデックス ルールに違反していることがわかったので、注文を false としてマークします。順序付きフラグがまだ true であることが確認(rèn)された場合は、そのページ更新の中央の要素でスコアを更新します。

func ConstructRules(rulesList [][]int) map[int][]int {
    rules := make(map[int][]int)
    for _, rule := range rulesList {
        rules[rule[0]] = append(rules[rule[0]], rule[1])
    }
    return rules
}

繰り返しになりますが、整數(shù)のリストを含む整數(shù)のマップとしてルールと番號のインデックスを備えた GetOrderedPage という関數(shù)と、ページ更新としての整數(shù)のリストであるページを作成します。この関數(shù)の出力としてスコアを返します。

各ページの更新を繰り返し、更新內(nèi)の各ページ番號でその番號のルールを確認(rèn)し、その番號のインデックスが現(xiàn)在の番號より小さい場合は、その番號を順序付けされていないとしてマークします。順序が正しければ、各ページ更新の最後にページ更新の中央要素でスコアを更新します。

これがパート 1 の要約になります。必要なのは、正しい順序で更新されたページのスコアを取得することだけです。

パート 2

パート 2 では、ページの更新が適切に行われているかどうかを確認(rèn)する必要があり、そうでない場合は、順番に更新する必要があります。

パート 2 でも同様のことを行います。各ページ更新を繰り返す必要があります。また、そのページ更新の各數(shù)値について、ルールに違反しているかどうかを確認(rèn)する必要があります。任意の數(shù)でルールに違反している場合は、順序付けられたフラグを false としてマークし、これをページ更新の順序を修正するために使用します。そのページ行/更新のページを更新した後、修正されたページ更新順序の中間要素でスコアを追加する必要があります。

47|53
97|13
97|61
97|47
75|29
61|13
75|53
29|13
97|29
53|29
61|53
97|53
61|29
47|13
75|47
97|75
47|61
75|61
47|29
75|13
53|13

75,47,61,53,29
97,61,53,29,13
75,29,13
75,97,47,61,53
61,13,29
97,13,75,29,47

ページ行またはページ更新とルールを取り込む CorrectPageOrder 関數(shù)を?qū)g裝する必要があります。すべてのルールに従うページを設(shè)定する新しいページ更新を作成する必要があります。

そこで、まず初期化された要素のインデックスを追跡し、その前に要素を移動する必要がある場合はインデックスを更新します。

そこで、ページ更新のすべての數(shù)値を反復(fù)処理し、ルール內(nèi)の數(shù)値の前にインデックスを設(shè)定します。ルール マップ內(nèi)でそのような數(shù)値が見つかった場合は、その數(shù)値のインデックスでインデックスを更新する必要があります。

要素の交換先のインデックスを取得したら、そのインデックスの前にスライスを作成してその番號をそれに追加し、そのインデックスの後にすべてを追加します。

func ReadFileSections(path string) [][][]int {

    fileBytes := ReadFileBytes(path)
    lines := []string{}
    separator := []byte("\n\n")
    for _, line := range bytes.Split(fileBytes, separator) {
        if string(line) != "" {
            lines = append(lines, string(line))
        }
    }

    sections := [][][]int{}
    for i, section := range lines {
        nums := [][]int{}
        lineStrs := strings.Split(section, "\n")
        separator := ","
        if i == 0 {
            separator = "|"
        }
        for _, lineStr := range lineStrs {
            if lineStr == "" {
                continue
            }
            numL := []int{}
            for _, numStr := range strings.Split(lineStr, separator) {
                num, _ := strconv.Atoi(numStr)
                numL = append(numL, num)
            }
            nums = append(nums, numL)
        }
        sections = append(sections, nums)
    }
    return sections
}

したがって、この関數(shù)は數(shù)値のインデックスを見つけて、その數(shù)値のルールに違反しないように最も左端 (リストの先頭) に配置します。その後、その數(shù)値を前に追加するスライスを作成します。そのインデックスを作成し、そのインデックスの後にすべてを追加します。

パート 2 はここまでです。ページの順序に矛盾があった場合は、ページの順序を更新しました。

ここ GitHub で私のソリューションをチェックできます。

Advent of Code ay n Golang: Ordering Pages ミスター?ディストラクティブ / コードの出現(xiàn)

コードの到來

結(jié)論

Golang の Advent of Code の 5 日目は以上です。何か提案があれば、またどのようにアプローチしたかを教えてください。何か良い解決策はありますか?

ハッピーコーディング:)

以上がCode ay n Golang の出現(xiàn): ページの注文の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中國語版

SublimeText3 中國語版

中國語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

デフォルトでGoの靜的リンクの意味は何ですか? デフォルトでGoの靜的リンクの意味は何ですか? Jun 19, 2025 am 01:08 AM

プログラムをデフォルトでスタンドアロンのバイナリにコンパイルします。主な理由は靜的リンクです。 1.よりシンプルな展開:依存関係ライブラリの追加インストールは、Linux分布全體で直接実行できます。 2。バイナリサイズの大きい:すべての依存関係を含むと、ファイルサイズが増加しますが、構(gòu)築フラグまたは圧縮ツールを通じて最適化できます。 3.予測可能性とセキュリティの高まり:外部ライブラリバージョンの変更によってもたらされたリスクを避け、安定性を高めます。 4.制限された操作の柔軟性:共有ライブラリのホットアップデートはできません。依存関係の脆弱性を修正するには、再コンパイルと展開が必要です。これらの機(jī)能により、CLIツール、マイクロサービス、その他のシナリオに適していますが、ストレージが制限されているか、集中管理に依存している環(huán)境でトレードオフが必要です。

GOでバッファーチャネルを作成するにはどうすればよいですか? (例えば、make(chan int、10)) GOでバッファーチャネルを作成するにはどうすればよいですか? (例えば、make(chan int、10)) Jun 20, 2025 am 01:07 AM

GOでバッファチャネルを作成するには、Make関數(shù)の容量パラメーターを指定するだけです。バッファチャネルは、指定された容量を超えない限り、受信機(jī)がない場合に送信操作が一時的にデータを保存できるようにします。たとえば、ch:= make(chanint、10)は、最大10個の整數(shù)値を保存できるバッファチャネルを作成します。バッファーされていないチャネルとは異なり、データは送信時にすぐにブロックされませんが、データはレシーバーによって奪われるまで一時的にバッファーに保存されます。それを使用する場合、注意してください。1。メモリの無駄や頻繁なブロックを避けるために、容量設(shè)定は妥當(dāng)でなければなりません。 2。バッファは、バッファーにメモリの問題が無期限に蓄積されないようにする必要があります。 3.信號は、リソースを保存するために、chantruct {}タイプを渡すことができます。一般的なシナリオには、並行性の數(shù)、生産者消費(fèi)者モデル、および差別化の制御が含まれます

Cのような手動メモリ管理なしでメモリの安全性をどのように保証しますか? Cのような手動メモリ管理なしでメモリの安全性をどのように保証しますか? Jun 19, 2025 am 01:11 AM

guensuresmemorysafetywithoutwithoutmanagemationgarbagecolectrection、nopointerariThmetic、safeconcurrency、andruntimechecks.first、go’sgarbagecollectorectivative -sunusedmemory、rieksanddanglingpointers.second、itdidilowsepointe

システムプログラミングタスクにGOにどのように使用できますか? システムプログラミングタスクにGOにどのように使用できますか? Jun 19, 2025 am 01:10 AM

GOは、Cなどのコンパイルされた言語のパフォーマンスと、最新言語の使いやすさとセキュリティを組み合わせているため、システムプログラミングに最適です。 1.ファイルとディレクトリの操作に関して、GOのOSパッケージは、ファイルとディレクトリが存在するかどうかの作成、削除、名前変更、チェックをサポートします。 OS.ReadFileを使用して、バックアップスクリプトまたはログ処理ツールの書き込みに適した1行のコードでファイル全體を読み取ります。 2。プロセス管理の観點(diǎn)から、OS/EXECパッケージのexec.command関數(shù)は、外部コマンドを?qū)g行し、出力をキャプチャし、環(huán)境変數(shù)を設(shè)定し、入力と出力フローをリダイレクトし、自動化ツールと展開スクリプトに適したプロセスライフサイクルを制御できます。 3。ネットワークと並行性の観點(diǎn)から、ネットパッケージはTCP/UDPプログラミング、DNSクエリ、オリジナルセットをサポートします。

GOの構(gòu)造インスタンスでメソッドを呼び出すにはどうすればよいですか? GOの構(gòu)造インスタンスでメソッドを呼び出すにはどうすればよいですか? Jun 24, 2025 pm 03:17 PM

GO言語では、構(gòu)造メソッドを呼び出すには、最初に構(gòu)造と受信機(jī)を結(jié)合する方法を定義し、ポイント番號を使用してアクセスする必要があります。構(gòu)造の長方形を定義した後、メソッドは値受信機(jī)またはポインターレシーバーを介して宣言できます。 1。func(rrectangle)領(lǐng)域()intなどの値受信機(jī)を使用し、rect.area()を介して直接呼び出します。 2.構(gòu)造を変更する必要がある場合は、FUNC(r*長方形)setWidth(...)などのポインターレシーバーを使用し、GOはポインターと値の変換を自動的に処理します。 3.構(gòu)造を埋め込むと、埋め込まれた構(gòu)造の方法が改善され、外側(cè)の構(gòu)造を介して直接呼び出すことができます。 4。GOは、Getter/Setterを使用する必要はありません。

GOのインターフェイスとは何ですか?また、それらを定義するにはどうすればよいですか? GOのインターフェイスとは何ですか?また、それらを定義するにはどうすればよいですか? Jun 22, 2025 pm 03:41 PM

Goでは、インターフェイスは、実裝を指定せずに動作を定義するタイプです。インターフェイスはメソッドシグネチャで構(gòu)成され、これらのメソッドを?qū)g裝する任意のタイプは、インターフェイスを自動的に満たします。たとえば、speak()メソッドを含むスピーカーインターフェイスを定義する場合、メソッドを?qū)g裝するすべてのタイプをスピーカーと見なすことができます。インターフェイスは、一般的な関數(shù)、抽象的な実裝の詳細(xì)、およびテストで模擬オブジェクトの使用に適しています。インターフェイスの定義は、インターフェイスキーワードを使用し、メソッドシグネチャをリストし、インターフェイスを?qū)g裝するためにタイプを明示的に宣言することはありません。一般的なユースケースには、ログ、フォーマット、さまざまなデータベースまたはサービスの抽象化、および通知システムが含まれます。たとえば、犬とロボットの両方のタイプは、話す方法を?qū)g裝し、それらを同じannoに渡すことができます

GOの文字列パッケージから文字列関數(shù)を使用するにはどうすればよいですか? (例えば、len()、strings.contains()、strings.index()、strings.replaceall()) GOの文字列パッケージから文字列関數(shù)を使用するにはどうすればよいですか? (例えば、len()、strings.contains()、strings.index()、strings.replaceall()) Jun 20, 2025 am 01:06 AM

GO言語では、文字列操作は主に文字列パッケージと組み込み関數(shù)を介して実裝されます。 1.Strings.Contains()は、文字列にサブストリングを含み、ブール値を返すかどうかを判斷するために使用されます。 2.Strings.index()は、サブストリングが初めて表示される場所を見つけることができ、存在しない場合は-1を返します。 3.Strings.ReplaceAll()は、一致するすべてのサブストリングを置き換えることができ、strings.replace()を介して交換の數(shù)も制御できます。 4.Len()関數(shù)は、文字列のバイトの長さを取得するために使用されますが、Unicodeを処理する場合は、文字とバイトの違いに注意を払う必要があります。これらの機(jī)能は、データフィルタリング、テキスト解析、文字列処理などのシナリオでよく使用されます。

IOパッケージを使用して、GOの入力ストリームと出力ストリームを使用するにはどうすればよいですか? IOパッケージを使用して、GOの入力ストリームと出力ストリームを使用するにはどうすればよいですか? Jun 20, 2025 am 11:25 AM

thegoiopackageProvidesInterfacesLikerEaderAnderandRitoHandlei/ooperationsUniformlyAcrossources.1.io.Reader'SreadMethodenablessablesSreadingSuourCessuchasfilesorhtttttttttts

See all articles