1read 100read
2012年3月ゲ製作技術207:  /* 簡単なプログラムをウプしよう */ (205) TOP カテ一覧 スレ一覧 2ch元 削除依頼
【ウディタ】WOLF RPGエディター 質問スレ 其の3 (819)
廃人から立ち直るためにゲーム製作 (163)
C# C# C♯ でゲームを作ろう Part2 (316)
新ジャンル『980円(税)』ゲーム化製作スレ (750)
推薦図書/必読書のためのスレッド in ゲ製作技術5 (625)
(゜(・)゜)ホモゲー作ろうよ(゜(・)゜) (659)

 /* 簡単なプログラムをウプしよう */


1 :02/06/27
比較的規模の小さい
ゲームやアルゴリズムをUPしたり
語り合ったりするスレッドです。
勉強用ですので、言語の選択についてや
ゲームが面白いかどうかの議論は禁止の方向で。
UPする方は使用言語を明記してください。
どうか盛り上がってください。おながいします。おながいします。

2 :02/06/27
削除依頼だしました。
糞スレ認定。

3 :02/06/27
とりあえず、迷路生成プログラム作りました…
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/meiro.txt
C++です。

4 :02/06/27
            o
            /  ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ /
           /   このスレは無事に  /
           /  終了いたしました    /
          / ありがとうございました  /
          /                /
         /   モララーより      /
         / ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄/
  ∧_∧  /                /∧_∧
 ( ・∀・) /                /(・∀・ )
 (    )つ               ⊂(    )
 | | |                   | | |
 (__)_)                  (_(__)

5 :02/06/27
>>2
そこを何とか。
プログラムを積極的にうpする
スレッドが無いのは寂しいので…

6 :02/06/27
>>4
……

7 :02/06/27

>>1
諦めるなよ。ちゃんとレスを付けて育てていけば、どこかの誰かがいっぱ
しのレスを付けてくれる。
それまで何とかジサクジエンでもいいからレスを付け続けろ。
諦めたらそこでおしまいさ。

8 :02/06/27
とりあえず>>1は(必要な時以外は)名無しになります。
>>7
がんばります。
いきなり終了ってのは
新手の「2げっとズザー」なんでしょうか。
今日は(日付変わってるけど)もう寝るので
明日からは日々の勉強の成果を
少しずつ上げていこうと思います。
レベルの高い人も、自信の無い人も気軽に参加してくださーい。

9 :02/06/27
ソースを上げるスレッド
http://game.2ch.net/test/read.cgi/gamedev/1005038280/
こっちを利用しる

10 :02/06/27
>>9 あんたが一人で使えYO!

11 :02/06/27
俺は伝統ある>>9のスレを支持。ていうかスレ立てる前にちとためらってクレヨン。

12 :02/06/27
ただでさえ人もカキコも少ない板なのに、同様の主旨のスレが
乱立して情報があちこちに散らばるのは良くないよ。

13 :02/06/27
>>># 一種の隔離スレです。<<<
あっちは最初にこんな風に書いてあるから感じ悪いし、
鯖に負荷が掛かるし、タブやらスペースが消えちゃうからダメダメ

14 :02/06/27
>>9
>ソースを上げるスレッド
http://game.2ch.net/test/read.cgi/gamedev/1005038280/
>こっちを利用しる
同感だな。おまえに一票いれておく。

15 :02/06/27

再利用かよ。最終カキコが02/04/28か・・・
誰が利用すんだよ。そんなの・・・
そりゃ気がつかねーぞ。 こっちを本スレにすりゃいいじゃんよ。

16 :02/06/27
>15
この板ではすんごい遅レスをたまに見かけたりするし、
問題ないと思う。
それはいいけど、普通スレ立てる前に検索くらいはするだろ。

17 :02/06/27

んじゃー聞きたいがこのスレはどうするつもり?
削除依頼か?

18 :02/06/27
>>17
削除依頼されて何のデメリットがあるのかね。
このスレを失うことで、一体誰が損をするというのかね。
君はそもそも何のために闘争しているのかね。

19 :02/06/27
今日は削除依頼どころじゃない騒ぎになってるね。
多分、例のコピペが貼られる→自然に下がるっていういつもの
パターンになっちゃう。
んでスレの存在を皆が忘れた頃に誰かが空age→「上げんなヴォケ」と
誰かが罵倒→再び下がる
みたいないつものパターンも考えられる。

20 :02/06/27
やっぱり終了AAウザいっす。
禁止にしてほスィ

21 :02/06/27
>>4をせばいいのら

22 :02/06/27
終了AA張ってるの一人でしょ
アクセス制限しろよ

23 :02/06/27

>>18
そりゃー誰も損はしないさ。>>1以外は。
一体、その古いスレに情報を書き込んで何がどうなる?
誰も見ていないスレに情報を集約してどうなるんだ?
事実、「古くなったスレの情報」に誰も興味が無くなったから書き込まな
かった。だから落ちた訳だろ?
誰だかは知らんが、古いスレに誘導してどうなるんだよ。

24 :02/06/27
>>23
どのみち意味などないと知っていて君は意味を求めている。
同じなんだよ。何もかも。
くだらない事はくだらない事であると気付いているなら
2chのあらゆる板の過去に習い、慣習に従えばいいだけなのよ。
無駄なエネルギーロスは賢明じゃない。新しい試みをするなら
もっと重要な物事に対してやればいい。

25 :02/06/27
ワケワカラン方向へっちゃダメ!

26 :02/06/27

んで? 古いレスを上げてどうすんの?
別段、この会話に意味を見出すつもりは一切ないが。
>>1 をそっちに誘導すんの?

27 :02/06/27
>どのみち意味などない

28 :02/06/27

なんだそりゃ。結局、どっちでもいいって事か・・・
この会話の意味って奴は本当になかったんだな。じゃあ上げるなよ・・・
まぁ、、、 どうでもいいがな

29 :02/06/27
今我々にできるのは、1が2chに繋ぐまでやきもきする事だけだ。

30 :02/06/27

>>29
了解した。
これを見て >>1 がどういう反応するか今から楽しみだ(W
楽しみは今日の夜だな。(WWWWW

31 :02/06/27
            o
            /  ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ /
           /   このスレは無事に  /
           /  終了いたしました    /
          / ありがとうございました  /
          /                /
         /   モララーより      /
         / ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄/
  ∧_∧  /                /∧_∧
 ( ・∀・) /                /(・∀・ )
 (    )つ               ⊂(    )
 | | |                   | | |
 (__)_)                  (_(__)

32 :02/06/27
激しくジサクジエン臭いレスがいっぱいだな

33 :02/06/27
>>32
重複禁止のルールを知らない時点で終わっていると思われる。
しかし、「古いから」という理屈があるとは予想していなかっただけに大収穫。
どこの駄板の習慣だろね。<古いから

34 :02/06/27
         | |‖│||
    ┌― | |‖│|| ―┬────
    |   | |‖│||   |
    |             | | ̄ ̄ ̄
    |   / ̄ ̄∨ヽ.  |  |
    |   /     ∨.  | |___
    |  /___________ヽ  |ガシャン
    |  / | \/_|ヽ  |
    |  | |  ゚| □| \.|
    |  | |  ゚|  |\__|つ
    |  | |  ゚|  |  |
_       ______________│
  \    /
    \/
        ∫ フー
   ∧,,∧ ∬       / ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄
   ミ,,゚Д゚ノ,っ━~  < 1よ、昔こ〜ゆ〜事されたのか?
_と~,,,  ~,,,ノ_. ∀  \  まぁいい、昔の事は聞かねぇから削除依頼出して来い
    .ミ,,,/~),  .| ┷┳━ \ ________
 ̄ ̄ ̄ .し'J ̄ ̄|... ┃

35 :02/06/27
>>3のプログラムをコンパイル(って言うんですよね)
したのも上げてホスィんですけど・・・プログラムに興味は
あるんですけど、C++はまだよく分からないので・・・お願いします・・・

36 :02/06/27
goto(sine);

37 :02/06/27
>>35
コンパイルだけならC++の知識はいらんぞ。フリーなのもあるから金もいらん。

38 :02/06/27
>>37
>35は>1が自スレを上げるために書いたレスだと気付け。
>1の文面を読めばこの糞素人が「自分の」スレに
どれだけ執着を持つタイプか伝わってくるだろ?

39 :02/06/27
bra $-2

40 :02/06/27
とりあえずスレ違いの話題には
あまりレスを付けない方針でいきましょう。
>>35
実行してもあまり楽しいものではないですが…
FLASHへの移植を検討中ですので、期待せずに待っててください。

41 :02/06/27
ポーカーゲームを作成中です。
検索とか使わないで今までの勉強の成果のみでやってみます。
いちおうポーカーが遊べる状態にはなりました。
あとは役の判定とかを作ればいいと思います。
1つのファイルにまとめて書いてしまっているので
見にくいでしょうが…
C++です
ソースのみ
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/poker01.txt
実行ファイル込み
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/poker01.zip
0(替える)と1(残す)をスペースで区切って5つ入力後Enterです。
<例>
0 1 0 0 1  (1,3,4番目のカードを替える)
変な入力をするとバグりますので
その時は、Ctrl + C で終了してください。

42 :02/06/27
足し算するプログラム。モード切替機能付
#include <stdio.h>
void main(){
int a,b,c;
char m;
printf (" *select mode* \n");
m=getchar();
if(m = '+'){
printf(" +tasizan+ \n");
scanf ("%d",&a);
scanf ("%d",&b);
c = a+b;
printf ("%d\n",c);
}
else{
printf ("kaihatutyuu..");
}
}

43 :02/06/27
モード切替機能がすごすぎるですね!
配列の勉強中。理想は式を打ち込んだら構文を解析して勝手に計算してくる奴作りたいdeath!

44 :02/06/28
ごめん、漏れ1に萌えちゃった。

45 :02/06/28
モード切替機能最高にかっこよすぎです。参考にさせていただきます

46 :02/06/28
異次元スレ

47 :02/06/28
異次元配列の勉強中です!

48 :02/06/28
>>43の式の構文解析って逆ポーランド記法だっけ?
y=ax+bが
yax*b+=に変換して計算するやつ。

49 :02/06/28
再帰下降じゃないのかなぁ・・・内部で式を逆ポーランドにするけども。

50 :02/06/28
ポーカーclassが形になりました。
変な入力をするとバグるのは相変わらずです…
カードの交換操作は>>41と同じです。
C++です。
ソースのみ
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/poker.txt
実行ファイル込み
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/poker.zip
相変わらず見難いソースですが…
他のテーブルゲームのclassをいくつか作れば
カジノになりますねー。

51 :02/06/28
>>48-49
イヤ、なんと呼ばれるのかは知らないが、そんな高級なのじゃないと思う。
入力を配列に入れて、その配列の要素が数字か文字か判定していくニダ
たとえば「15*3」と入力する。プログラムはそれを配列に入れ、まず変数aに15を入れ、*を読み込んで掛け算モードにして、
3を読み込んで変数bにいれて計算。配列の中身を一つずつ調べてそれが数字か文字か判定するって感じかな!
しかし、「{(10+3)*5}/5」とかはどうやってやるのかなあとか思うので、みんな考えてチョ
まあコンピュータにやらせるなら逆ポーランドは便利な記述法なのかなと思う

52 :02/06/28
>>51
僕はまだ、クイックソートやマージソートが
何をやっているのか、ってのがやっと解りはじめた
程度のヘタレなんですが…
難しいですね。
全くと言っていいほど、やり方が思いつかないです。
()内の式を再帰で渡す形でバラバラにしていくのかなぁ?
頭の体操になりそうなので、毎日ちょっとずつ考えよう…

53 :02/06/28
俺は51だが、俺のレベルもそのくらいだYo!>52
のほほんと頑張ろうぜ

54 :02/06/29
逆ポーランド記法は、スタックを使って実現。
まず、逆ポーランド記法に数式をなおす。
{(10+3)*5}/5 → 10 3 + 5 * 5 /
と言うようになる。
まずは、数式を逆ポーランド記法になおす関数をつくり、結果を配列A[]にいれる。
次に、逆ポーランド記法の計算をする関数を作る。
A[]から一つずつ要素を取り出して、演算子かどうかを判断しながらスタックに格納していく。演算子だった場合は、計算を行う。
動作1:数字がきているので、そのままスタックに積む。
|10|
動作2:数字がきているので、そのままスタックに積む。
|10| 3|
動作3:演算子"+"がきているので、A[0] + A[1] をして、A[0]に代入。
|13|
動作4:数字がきているので、そのままスタックに積む。
|13| 5|
動作5:演算子"*"がきているので、A[0] * A[1] をして、A[0]に代入。
|65|
動作6:数字がきているので、そのままスタックに積む。
|65| 5|
動作7:演算子"/"がきているので、A[0] / A[1] をして、A[0]に代入。
|13|
動作8:要素がなくなったので、A[0]を出力して終了。

55 :02/06/29
勉強になりますた

56 :02/06/29
>>50
不覚にもハマッタよ。>>ポーカー
でも、もしかしたら
ロイヤルストレートってところで
入力をミスってオジャンにナターヨ。
入力ミスのチェックはしないのかな?

57 :02/06/29
すいません、ポーカーclassにバグがありました。
>>56さんの書き込みを見て、何となくソースを
見直してみたんですけど、Flashの判定でバカなミスをかましてました。
コッソリ修正しておきましたので報告です。URLは>>50と同じです。
>>56
僕がヘタレだからエラーチェックが入っていないってのも
あるんですけど、後で再利用したり、手を加えることを考えて、余計な
コードは書かないようにしています。暇があったら改良してやって下さい。
あと、すいませんが遊ぶ時は修正版をダウンロードし直して下さい…

58 :02/06/29
>>54
>逆ポーランド記法に数式をなおす。
これがえらい難しいですね…
難しいというか、ただ面倒くさいだけなのかもしれませんが。
検索すれば答えはあるんでしょうけど、なんとか
自分で作ってみたいなぁ。

59 :02/06/29
逆ポーランドに直すのはかなり簡単だろ。
構文解析でも基礎中の基礎じゃないか。
優先順位と括弧にだけ気をつければ良いんだから。

60 :02/06/29
とりあえずここまで… 残りは後で考えます
#! /usr/bin/env ruby
def infix_to_postfix(expr)
 stack = ['(']
 result = []
 operator_priority = {
  '*' => 50, '/' => 50,
  '+' => 20, '-' => 20,
  '(' => 10, ')' => 10,
 }
 expr.each{ |x|
  if '+ - * /'.split.include?(x)
   # operator
   while operator_priority[stack.last] >= operator_priority[x]
    result.push(stack.pop)
   end
   stack.push(x)
  else
   result.push(x) # operand はそのまま出力
  end
 }
 while not stack.empty? and operator_priority[stack.last] >= operator_priority[')']
  result.push(stack.pop)
 end
 result.pop # 最後は'('が入ってるので捨てる
 result
end
puts infix_to_postfix(ARGV[0].split).join

61 :02/07/01
逆ポーランドへの変換プログラムです。
+ - * / 演算に対応しています。小数の使用可です。
()は使えません。入力時にスペースとタブを入れても大丈夫です。
今回はC言語です。
ソース
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/MtoB.txt
実行ファイル込み
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/MtoB.zip
なんか、ソースのコメントからして駄目さがにじみ出ていますが。
>>59
とりあえず、自分の理解した範囲で挑戦しました。
いずれ、完璧なものが出来たらUPさせていただきます。
>>60
rubyなのですか?僕には読めません…スマソ

62 :02/07/01
逆ポーランドが終わったら正規表現をやると良い。
たぶん、コレも興味が持てるだろう

63 :02/07/01
期待age
上にあるのは糞スレばっかり。
健闘を祈ります。

64 :02/07/01
kusosure washo-i

65 :02/07/04
プログラマの卵がんがれー

66 :02/07/05
最近はアルゴリズムより言語の仕様の勉強中心なので
UPする(意味がある)ものが少ないです。というわけで
>>3をFLASHに移植してみることに。
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/Maze.swf
(IEならF5で)リロードしてみてください。
毎回違った迷路が作成されるはずです。今はこれだけです。
これをもとに、ちょっとしたミニゲームを作る予定…(未定ですが)
ソース(ファイルを開くのにFLASH5が必要です)
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/Maze.zip
なんか、FLASHだと(C/C++と比べて)混沌としてしまいますね。
でも、ActionScriptが分かる人なら簡単に改造できると思います。
ソースの80%ほどは、>>3のC++のソースからのコピペで済みました。
次回のUPまでに、もう少しコメントをしっかりと書いておきます。

67 :02/07/05
メタセコイアっぽいマウスによるカメラの制御方法です。
回転にはクォータニオンを使ってます。
void CMouseListener::RotateCameraPosition()
{
int dx = mouseoldx - mou;
int dy = mouseoldy - mousey;
float dtheta1 = dx*D3DXToRadian(1)/2;
float dtheta2 = dy*D3DXToRadian(1)/2;
D3DXVECTOR3 axis1 = D3DXVECTOR3(0.0f,1.0f,0.0f);
//x-z平面上で見たときの角度を取得
float thetaaxis2 = (float)atan2(-vCameraPos.x,-vCameraPos.z);
//π/4回転させる
D3DXVECTOR3 axis2 = D3DXVECTOR3(cosf(thetaaxis2),0,-sinf(thetaaxis2));

//続く

68 :02/07/05
D3DXQUATERNION q1,q2,
qi1,qi2;//逆クオータニオン
//dthetaだけaxisに対して回転
D3DXQuaternionRotationAxis(&q1,&axis1,dtheta1);
D3DXQuaternionRotationAxis(&q2,&axis2,dtheta2);

//逆クォータニオンを設定
D3DXQuaternionInverse(&qi1,&q1);
D3DXQuaternionInverse(&qi2,&q2);
//元のカメラの位置ベクトル成分を持つクォータニオン
D3DXQUATERNION qPos = D3DXQUATERNION(vCameraPos.x,vCameraPos.y,vCameraPos.z,0.0f);
D3DXVECTOR3 vNewPos1,vNewPos2;
//それぞれの軸についてカメラの位置を回転させたものを求めて
D3DXQUATERNION qNewPos1 = q1*qPos*qi1;
D3DXQUATERNION qNewPos2 = q2*qPos*qi2;
//ベクトルとして合成
vNewPos1 = D3DXVECTOR3(qNewPos1.x,qNewPos1.y,qNewPos1.z);
vNewPos2 = D3DXVECTOR3(qNewPos2.x,qNewPos2.y,qNewPos2.z);
//正規化
D3DXVec3Normalize(&vCameraPos,&(vNewPos2 + vNewPos1));

//元の大きさを持たせる
vCameraPos*= Dist;
//変換行列を作成、IDirect3DDeviceに与える
ApplyNewCameraPosition();
}

69 :02/07/05
ゴメソ訂正
×//ベクトルとして合成
○//ベクトルとする
です。んでは学校行ってきます

70 :02/07/06
ポインタの勉強をしたので
>>3の迷路生成クラスを、少し改良しました。
コンストラクタに二つの仮引数を渡すことで、迷路の大きさを自由に決定できます。
ソース
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/newMEIRO.txt
実行ファイル込み
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/newMEIRO.zip
変数名、コメントなども少しだけ改めました…精進します。

71 :02/07/06
>>67-69
3Dですか〜。ゲーム製作の香りがしますねぇ。
僕は、どちらかというとゲームのルール自体は
2D前提で考えますね。(表示には3Dも使ってみたいですが)
ローグみたいなゲームを製作中です。
細かいデータをチマチマといじるのが好きなので。
あと、書き忘れましたが>>70はC++です。

72 :02/07/06
>>71
実行してないから分からないんだが、生成した迷路データで
3D迷路を探索するゲーム作ったら?
Wizとか女神転生とかみたいな感じの。

73 :02/07/06
>>71
どうもです。一人でちまちまコード打ってると気分が滅入ってくるので
これからもちょくちょく貼り付けさせてもらいにくるかもしれません。

74 :02/07/07
役立たずかも
template<typename T, typename U>
T co_interface_cast(U from)
{
 T ret;
 HRESULT result;
 result = from->QueryInterface( __uuidof(T), reinterpret_cast<void**>( &ret ) );
 if ( FAILED( result ) ) {
  ret = NULL;
 }
 return ret;
}

75 :02/07/07
>>74
ゲーム作るのにCOM使うのってどんなときですか?
xファイルを読み込むのぐらいにしか使ったことないyo

76 :02/07/09
>>70
少しソースを見たけど
#include<iostream>
#include<cstdlib>
#include<ctime>
#include<new>
は良くない無いなぁ、拡張子はきちんとつけようよ。

77 :02/07/09
>>76
ネタはageて書こうぜ

78 :02/07/11
あまり上げるネタがないですねぇ…
迷路ばっかりいじくっててナンですが
http://www.geocities.co.jp/SiliconValley-Cupertino/8770/mimiMaze.html
↑↓←→キーで移動できます。ミミズです。壁(固い土)も掘り進めます。
スクリプトの処理が多少重いので、環境によっては動きが悪いかもしれません。
これから、どんなゲームにしようか考えます。
>>78
大体は本で読んだとおりに書いているのですが…
ヘッダーファイルの拡張子は付けた方がいいのでしょうか?
ちょっと、検索してみます。すみませんが、まだ言語の理解が足りてないので…

79 :02/07/11
>>76
最近、
#include<hoge>
ってくっつけて書くのが流行ってるのかなぁ?

80 :02/07/11
関数呼び出しと同じ感覚なんじゃない?
include が関数名で(笑)。

81 :02/07/11
× #include<hoge>
○ #include <hoge>
ですか?
コンパイラによっては正しく認識されなかったり
するのでしょうか…(僕はVC++6.0しか使ってないです)

82 :02/07/11
#inluce<hege>
でも問題なしなんだろうけど、気になるね。
#include <hoge.cpp> とか #include <hoge.c>
で直接コンパイルしちゃう方法もあるから、ヘッダーファイルって事を明らかにする為にも
#include <hoge.h>
の方がいいとおもうよ。

83 :02/07/11
#include<iostream>
#include<cstdlib>
#include<ctime>
#include<new>
でもコレはC++標準じゃねーか

84 :02/07/11
>>83
スマン、俺の知識が古かったのかもしれん。「C++標準」って言葉の意味が分からん。
VC++ではそうなるってこと?
それとも全てのC++で共通ってことなのか?
余計なこと言ったかもしれんな、ってくるよ・・・。

85 :02/07/11
すべてのC++で共通。
Standard C++規格のライブラリで規定されている

86 :02/07/11
>>84
調べてみましたが、C++ではファイル名の
重複を避ける為、拡張子を付けない形になっている
とのことでした。(違うのかもしれませんが)
ちなみに、conio.hはcconioってのが無いみたいなので
適当に#includeしちゃいました。
>>72
遅レスですが
実際にRPGみたいなゲームを作るときは
僕はランダムマップにはしないと思います。
出現する敵、アイテムに加えてマップまでランダムだと
バランスを取るのが大変ですし、1000回遊べる〜とかには興味がないので…
1〜2回でも満足できるゲームにするつもりです。

87 :02/07/11
あと、>>78はFLASH5です。書き忘れでした。

88 :02/07/12
よくわかんないけどSTGの弾幕の数式書き出すプログラム作ってよ。おながいします。

89 :02/07/12
while(1)
{
printf("88ってよし\n");
}

90 :02/07/12
>>88
数式じゃなくて、書き出すプログラム?
余り関係ないが、参考になるかも。
http://www.asahi-net.or.jp/~cs8k-cyu/bulletml/index.html

91 :02/07/12

 今…
     88が…
          …  く ! ! ! ! ! ! !

92 :02/07/12
>>90
ギャー!! これじゃー!! たぶん…
サンクスコーヽ(´д`)ノ
いやね、当方プログラマじゃないしなる気もないのでなんかスクリプトっぽいので
ミーシューでSTGを作ろうと思ってたのですよ。そしたらってよしとか言われてるんです。
もうね、くかと、死ぬかと。
ごめんなさい。

93 :02/07/12
ぷよぷよ消しアルゴリズムです。2回再帰しなくても良いようお知恵をお貸し下さい。
#define BX  6
#define BY  10
for( int x = 0; x < BX; x ++){
  for( int y = 0; y < BY; y ++){
    if( block[ x][ y].getActived()){
      int cnt = checkEraseBlock( x, y, block[ x][ y].getColor());
      if( cnt > 4) EraseBlock( x, y, block[ x][ y].getColor());
    }
  }
}
int checkEraseBlock( int x, int y, int color, int cnt)
{
  if( color == block[ x][ y].getColor() && block[ x][ y].getActived()){
    cnt ++;
    cnt = checkEraseBlock( x - 1, y + 1, color, cnt);
    cnt = checkEraseBlock( x - 1, y - 1, color, cnt);
    cnt = checkEraseBlock( x + 1, y + 1, color, cnt);
    cnt = checkEraseBlock( x + 1, y - 1, color, cnt);
  }
  return cnt;
}
void eraseBlock( int x, int y, int color)
{
  if( color == block[ x][ y].getColor() && block[ x][ y].getActived()){
    eraseBlock( x - 1, y + 1, color);
    eraseBlock( x - 1, y - 1, color);
    eraseBlock( x + 1, y + 1, color);
    eraseBlock( x + 1, y - 1, color);
    block[ x][ y].setErase();
  }
}

94 :02/07/12
すいませんgetActived()ってなんですか?
で,分岐してからcolor調べずに分岐する前に調べたらどうでしょう?

95 :02/07/12
フィールドと同じ配列を用意して、
状態を保存しておけば?

96 :02/07/12
そう。
>      int cnt = checkEraseBlock( x, y, block[ x][ y].getColor());
>      if( cnt > 4) EraseBlock( x, y, block[ x][ y].getColor());
つながってる個数を調べるのと消すのを同時にやってるのが悪い。
cntは、各ブロックに覚えさせておいて、全ブロックのcntを計算してから
4以上のブロックのぷよを消せば、2回目の再帰は要らない。
再帰を使わないやり方もあるけど、ぷよぷよの場合は、返って効率悪いかな。

97 :02/07/12
ちなみに、配列で状態を保存しておけば一度捜査したところの無駄な再帰は無くなる

98 :02/07/12
>>94
各blockにstateflgを記録し、Actived(存在する)ならtrueを返します。
isActivedに変えました^^;colorを調べる順番変更させていただきました。
>>95>>97
blockの中に状態保持フラグがあり、そこで同動作を実現しております。
>>96
再帰の途中では、cnt<4の状態があり、この状態で2度と訪れない場合が
存在します。cnt>4条件で消していると、これらが消されないように思うのですが、
どうでしょうか?

99 :02/07/12
再帰なんだけど、末尾再帰ではなく、
関数から戻るフェーズで一番下の層からの戻り値(カウント)をセットすれば?

100read 1read
1read 100read
TOP カテ一覧 スレ一覧 2ch元 削除依頼
-RPGツクール総合スレッド@製作技術(Part15)- (286)
-RPGツクール総合スレッド@製作技術(Part15)- (286)
世界観・キャラをメインにシナリオを語るスレ (629)
C言語×ダンジョン×学園なゲームを創りたいスレ (678)
ゲームにおけるデータ構造・クラス設計・パターン2 (600)
F1チーム運営シム 製作スレ (432)
--log9.info------------------
字(あざな)の起源 (280)
「城の守りが堅くて落とせない」とか言ってるけど (145)
中国の城ってどんな感じ? (105)
【天下の険】 竜 王 城 【難攻不落】 (259)
語尾に『・・・』をつけて雑談しよう・・・ (452)
【三戦都構想】三戦板維新の会【新自治】 (376)
■秀吉の膨張ぶりには驚くしかない■ (156)
【八戸】 楊奉について語るスレ 【白波】 (103)
自治新党9周年おめでとう! (114)
三国志最高の軍師って… (409)
関羽と俺の関係(復刻版) (472)
徳川家康の生涯って面白みがないし、人気ないのも分かる気がする (242)
馬謖がベギラゴンを使えたら北伐は成功していた (178)
なんで伊達政宗ってアンチ多いの? (414)
『三国志』の知識が実生活で役立った事。 (112)
関が原の戦いのIF設定を語るスレ (212)
--log55.com------------------
コウタとショウコの兄妹愛に萌えるスレ
【初心者】機動戦士ガンダム EXVSFB質問スレpart10
トランスフォーマー参戦希望
ガンダムトゥルーオデッセイ2はやくしろ
ガンダムバトルオペレーションNEXT晒しスレ 7
今のスーパー系とリアル系の境目って何なんだ?
ガンダム無双 総合 Part86
【PS3】機動戦士ガンダムバトルオペレーション#1336