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

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

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

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

Q&A

1回答

2614閲覧

C# 乱数を用いて上下左右に線を伸ばす

退会済みユーザー

退会済みユーザー

総合スコア0

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

0グッド

1クリップ

投稿2016/04/19 04:56

C#で迷路を自動生成するコードを書いていて、迷路の内壁にあたる部分をつくっているのですが
詰まってしまいました。今はenumを使って上下左右に線が伸びて壁になるようにしているところで、そこを
どうやって作成していくべきなのかが分からなくなってしまいました。
解法またはヒントでもいいので教えてください。

以下のコードは内壁の部分の現在の状況です。
外枠の部分は作成できているのでそこは省略します。
考えている仕様ですが、縦のラインと横のライン、出入り口の数(最小2、最大4)をそれぞれテキストボックスに数値を入力することでその数値に応じた大きさの迷路が作成されるようにしようとしています。
どういうことかというと、横のマスの部分に20、縦のマスの部分に25を入力すると横20マス、縦25マス分の迷路が自動生成される。というような感じで外枠の部分を作っていてそれに応じて中の壁も作られていくというふうにしたいのです。

private void utikabe(object sender, EventArgs e) { Random rn = new Random(); //描画先とするImageオブジェクトを作成する Bitmap bmp = new Bitmap(this.pictureBox1.Width, this.pictureBox1.Height); //ImageオブジェクトのGraphicsオブジェクトを作成する Graphics g = Graphics.FromImage(bmp); for (int i = 1; i <= 50; i++) { int iRandom = rn.Next(1, 4); switch (dir[i]) { case 方向.上: g.DrawLine(Pens.Black, 0, 0, 0, 20); break; case 方向.右: g.DrawLine(Pens.Black, 0, 0, 20, 0); break; case 方向.左: g.DrawLine(Pens.Black, 0, 0, 0, -20); break; case 方向.下: g.DrawLine(Pens.Black, 0, 0, -20, 0); break; } } //リソースを解放する g.Dispose(); //PictureBox1に表示する pictureBox1.Image = bmp; } コード

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

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

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

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

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

guest

回答1

0

迷路をどのように自動生成するか、は純粋に数学の問題であり、その数学の問題を実際に解く手順はアルゴリズムと呼ばれます。迷路生成のアルゴリズムでは、棒倒し法、穴掘り法、壁延ばし法の三つが有名です。

迷路自動生成アルゴリズム

それっぽい迷路をお手軽に作るには、壁延ばし法が向いていると思います。壁延ばし法のメリットは、「だいたいこういうルート」という大まかなルートが定まるような壁を最初に配置した状態から開始することにより、単純すぎる迷路が生成されるのを回避することができることもあります。つまり、完全に自動生成すると、たとえば周囲壁だけからアルゴリズムを実行すると、左上にスタート、右下にゴールがあるような迷路において、まっすぐ対角線上に正解ルートがあってあとは枝葉、とか、まっすぐ右に向かって最後だけ下にいく正解ルート、みたいなのが生成される可能性があります。スタートの下に左の壁から生えてきた壁を右壁近くまで延ばして逆にゴールの上に右から生えてきた壁を左壁近くまで延ばす、という初期状態から始めると、必ず大きな流れとしては Z 状になるので、そこそこ難しい迷路が作られます。

投稿2016/04/19 11:52

unau

総合スコア2468

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問