[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 701- 801- 901- 1001- 2chのread.cgiへ]
Update time : 05/10 16:01 / Filesize : 349 KB / Number-of Response : 1002
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

七行プログラミング part2



1 名前:デフォルトの名無しさん [02/04/15 12:09]
7行×79文字なら言語は問いません。
過去作品は>>2-5を参照。

■前スレ
pc.2ch.net/test/read.cgi/tech/984182993/

792 名前:デフォルトの名無しさん [02/09/17 22:21]
>>789
ちょっと面白かった。
でもわずかにチカチカするのでちょっとだめかもw

フルスクリーンのせいでアプリをひとつ間違って閉じたのに気づかなかったぞゴルァ

793 名前:デフォルトの名無しさん mailto:sage [02/09/17 22:32]
つーか、Cなり何なりで、上のバイナリコードを吐き出すようにすれば、
もっと簡単に試したのではなかろうか。
main(){char data[]={...};fwrite(data,1,sizeof(data),stdout);}
みたく。

794 名前:デフォルトの名無しさん mailto:sage [02/09/17 23:42]
>>789
Win2k飛ばされますた
>>793
16バイトで出来てることに意味があるのでせう
逆アセンブルリスト見て嘆息

795 名前:デフォルトの名無しさん [02/09/18 16:11]
コードをアセンブラで書いて、インストラクションコードを
>>793みたいに文字列として埋め込むのはありでしょうか?
typedef int(*f)();
((f)"....")(); //呼び出し

796 名前:デフォルトの名無しさん mailto:sage [02/09/18 19:40]
>>795
良いと思うけど、普通は逆にオブジェクトコードが増えると思うよ

797 名前:デフォルトの名無しさん mailto:sage [02/09/18 19:40]
オブジェクトコード埋め込みの方が…ですね、スマソ

798 名前:トリッキーの1 mailto:sage [02/09/18 21:29]
ご無沙汰してました。相変わらず皆さん凄いですね。勉強になります。
近いところでは囲碁面白いですね。でも囲碁のルールが解らないので残念です。
>>771
半角スペース2個は全角1個にしないと、貼り付けるときに消えてしまいますよ
それと、「3,3:4,4:2,4:2,5:2,6:2,8」と入力すると相手の石の上に自分の石が来るけれど、
これは囲碁のルールで正しいんですか?

799 名前:デフォルトの名無しさん mailto:sage [02/09/18 22:39]
LZW系の展開・圧縮
使い方は>>752と同じ

同じ辞書を使い続ける6行版
int*Q,N[16384],S,T,U,V,F,G,P,C,X,Z;p(a,b){for(;b--;++S>7?putchar(T),S=T=0:0)T=T
+T|a>>b&1;}g(a){for(G=0;a--;G=G+G|V>>--U&1)!U?U=8,V=getchar():0;}a(){F<1<<12?1[
Q=N+F*4]=X,Q[2]=C,Q[3]=N[C*4],*Q=0,N[C*4]=F++:0;}r(x){p((x>256?r(N[x*4+2]),N[x*
4+1]:(X=x))-1,8);}main(c){for(G=F=257;G--;)1[Q=N+G*4]=G;for(--c?g(8),C=V+1:0;g(
c?8:12),c?C:~V;C=c?!Z?p(C,12),a(),X:Z:(G=X,r(Z<F?Z:C),Z<F||p(G-1,8),P++&&a(),Z)
)for(Z=c?X=V+1,N[C*4]:G;c*Z&&1[Q=N+Z*4]-X;Z=Q[3]);p(0,7);}

辞書が一杯になると再構築する7行版
int*Q,N[16384],S,T,U,V,F,G,P,C,X,Z;i(){for(G=F=257;G--;*Q=Q[2]=Q[3]=0)1[Q=N+G*4
]=G;}p(a,b){for(;b--;++S>7?putchar(T),S=T=0:0)T=T+T|a>>b&1;}g(a){for(G=0;a--;G=
G+G|V>>--U&1)!U?U=8,V=getchar():0;}a(){F<1<<12?1[Q=N+F*4]=X,Q[2]=C,Q[3]=N[C*4],
*Q=0,N[C*4]=F++:i();}r(x){p((x>256?r(N[x*4+2]),N[x*4+1]:(X=x))-1,8);}main(c){i(
);for(--c?g(8),C=V+1:0;g(c?8:12),c?C:~V;C=c?!Z?p(C,12),a(),X:Z:(G=X,r(Z<F?Z:C),
Z<F||p(G-1,8),P++&&a(),Z))for(Z=c?X=V+1,N[C*4]:G;c*Z&&1[Q=N+Z*4]-X;Z=Q[3]);p(0,
7);}

800 名前:デフォルトの名無しさん mailto:sage [02/09/18 22:54]
>>773
ほらよ。多少の誤差には眼をつぶれや。

#include <stdio.h> // printf()
#include <stdlib.h> // rand()
int main(){
printf( "3.1415926535897932384626433832795" ) ;
for (;;) printf( "%d",rand() ) ;
return 0 ;
}




801 名前:デフォルトの名無しさん mailto:sage [02/09/18 22:55]
後はランダムかよ

802 名前:デフォルトの名無しさん mailto:sage [02/09/18 23:08]
お題:素数列挙

803 名前:デフォルトの名無しさん mailto:sage [02/09/18 23:09]
p2pの七行があったらすごいよね。なんて言って見るテスト

804 名前:>>802 mailto:sage [02/09/18 23:15]
printf(char*,...);main(){int z,i=1;for(;z=i++;z?0:printf("%d,",i))while(i%z--);}

1文字オーバーなのは秘密だ。

805 名前:デフォルトの名無しさん mailto:sage [02/09/18 23:24]
>>802
外出だったりする

806 名前:デフォルトの名無しさん mailto:sage [02/09/18 23:32]
>>805
>>74 >>81やね

807 名前:デフォルトの名無しさん mailto:sage [02/09/18 23:37]
>>804
1文字縮めてみますた
printf(char*,...);main(){int z,i=1;for(;z=i++;z||printf("%d,",i))while(i%z--);}

808 名前:804 mailto:sage [02/09/18 23:53]
おぉ、さんきゅー!
そうか、|| か。なんかPerlっぽい。

809 名前:デフォルトの名無しさん mailto:sage [02/09/19 01:06]
>>807
gcc -ansi -pedantic だとprintf(char*,...)は通らず。
ANSI C forbids data definition with no type or storage class
printf()を削除すれば通るので、そっちの方がよい?

1文字縮めてみた。
printf(char*,...);main(z){int i=1;for(;z=i++;z||printf("%d,",i))while(i%z--);}

810 名前:デフォルトの名無しさん mailto:sage [02/09/19 01:14]
これではだめですかね。引き数なしで実行が条件ですが。
main(i,z){for(;z=i++;z||printf("%d,",i))while(i%z--);}



811 名前:デフォルトの名無しさん mailto:sage [02/09/19 01:22]
>>810
bcc32でも動きますね。しかもgccよりも速かった。

812 名前:デフォルトの名無しさん mailto:sage [02/09/19 01:29]
コンパイラを選ぶのはどうかと思う

813 名前:デフォルトの名無しさん mailto:sage [02/09/19 02:00]
>>810 Solaris cc, GNU gcc, Borland bcc32 でコンパイル・実行できますた。
>>807 上記すべてのコンパイラでprintfの宣言がおかしいといわれますた。
>>812 短くするためならコンパイラどころかアーキテクチャすら選択するのが最近の風潮らしいです。

814 名前:デフォルトの名無しさん mailto:sage [02/09/19 02:04]
>>803
p2pの何だ?

815 名前:デフォルトの名無しさん mailto:sage [02/09/19 03:47]
囲碁、申し訳ないんだが、
コンパイルして実行したら、
1の列を指定すると落ちるんだけど。
(ex:1,5)
バグ?


816 名前:デフォルトの名無しさん mailto:sage [02/09/19 04:06]
>>798>>815
囲碁、cygwin+gccやSolaris+ccでは正常らしい動作してますね
bcc32だと動作は正常のようでも、表示がおかしくなりますね
ANSI準拠っぽいソースだけど、どっかしらコンパイラ依存があるんでしょうね
>>771さんはいないようだし、ここはひとつトリッキーの1氏のご助力を!

817 名前:デフォルトの名無しさん mailto:sage [02/09/19 08:15]
プロトタイプ宣言無しで printf 使うのって好かんのだけどどうよ。
…っと言っても>>810、VC++.NETでもdmc++でも通るな。

int printf(char*,...); ... にすれば>>809行けるね。

818 名前:817 mailto:sage [02/09/19 08:16]
あーでも、宣言省略すれば int printf( ... ); 扱いになるんだっけ。Cって。
それならOKか。

819 名前:デフォルトの名無しさん [02/09/19 17:45]
>>810
>main(i,z)
Cって引数の型を省略するとintになるってこと?


820 名前:デフォルトの名無しさん [02/09/19 20:40]
円周率は

#include <stdio.h>
main(){printf("3.14159265358979323846264338327950288419716939937510582097494");
/* 以下略 */
}

よりも桁が多いことを願います。

とりあえず、職人さんに

(~~~゚∀~~)~~゚ メダマ ボーン




821 名前:デフォルトの名無しさん mailto:sage [02/09/19 20:43]
#include <stdio.h>
main()
{
char* url = "www.prokofiev.ru/prikol/text/t5/pi.htm";
system(url);
return 0;
}


822 名前:デフォルトの名無しさん mailto:sage [02/09/19 23:29]
>>814
不特定多数なWinMXみたいな奴でなくて、
相手を登録して交換するスタイル。Grooveとかがそんな感じかなぁ。
七行でできたらビックリだけどね。CUIでそういうの聞いたことないし。

823 名前:デフォルトの名無しさん mailto:sage [02/09/20 00:48]
それもP2Pかもしれないけど、
P2P=ファイル交換じゃないぞ

824 名前:デフォルトの名無しさん mailto:sage [02/09/20 04:32]
なんにせよ、もしできたら凄く便利だと思う

825 名前:デフォルトの名無しさん mailto:sage [02/09/20 04:57]
便利って・・・・・・別に7行でも覚えられるわけで無し・・・・・・
ぱっと思いつく最小のメディアであるFDに収まる1.44MBに入れば何だって同じ気が。
面白いけどね。

826 名前:デフォルトの名無しさん mailto:sage [02/09/20 08:53]
今更ながら>>800にワラタ

827 名前:トリッキーの1 mailto:sage [02/09/20 15:54]
円周率です。意外と七行は簡単でした。オイラーの公式使ってますので収束遅いです。

#include <stdio.h>
#define s ( 5000 /*←希望する桁数*/ /4+2)
int main(){int i,n,c,t,j,l,a[]={4,9},r[s][4]={0,0,8,12},k=10000;for(n=0;n<s*15
;n++)for(i=0;i<2;i++){for(c=t=j=0;j<s;r[j++][i]+=((n&1)*-2+1)*l/(2*n+1))t=(l=k
*t+r[j][i+2])%a[i],c=(l=k*c+(r[j][i+2]=l/a[i]))%(2*n+1);for(t=0,j--;j+1;r[j--]
[i]%=k)t=(r[j][i]+=k+t)/k-1;}for(i=s-(t=1);i+1;*r[i--]%=k)t=(*r[i]=k+*r[i]+r[i
][1]+t)/k-1;printf("%d.",**r);for(i=1;i<s-1;printf("%04d",*r[i++]));return 0;}

828 名前:トリッキーの1 mailto:sage [02/09/20 15:56]
こうやってみるとまだまだ短くなりそうですね。桁数固定にすれば後一行は軽そうです。

829 名前:デフォルトの名無しさん [02/09/20 20:47]
復活直後にでかいのを持ってきましたね。実質5行だし。相変わらず凄い。

7行にするのって、1字1字縮める技術ももちろんあるけれど、
組む前にデータ構造とアルゴリズムをなるべく文字数を減らすことを念頭に
構想する才能が必要だと思うが、それは知識と知恵の両方を要求するよね。
色々なネタで7行達成している常連の職人さんたちはかなりハイレベルだと思った。

830 名前:デフォルトの名無しさん mailto:sage [02/09/20 20:54]
有名人が出てくるたびにヨイショするこの雰囲気、
どうにかならんもんかねぇ。
名無しで新しいアイデア出てきても「たいしたことない」と言ってのけるのに。



831 名前:デフォルトの名無しさん mailto:sage [02/09/20 20:55]
本人がageてないのに他人がageるのも正直ウザい

832 名前:デフォルトの名無しさん mailto:sage [02/09/20 21:04]
ただのひがみかもしれないがマジレス。
有名人をよいしょしているわけではなく、
優れたプログラムを書く人をほめているのでは?

833 名前:デフォルトの名無しさん mailto:sage [02/09/20 21:05]
>>799
UNISYSに通報しますた

834 名前:デフォルトの名無しさん mailto:sage [02/09/20 21:29]
はいはい、そこ雰囲気悪くしない!
作品いっぱい出るのはいいことだし、批評はその作者の次に繋がるので良し!
でも830、無意味な煽りは入れない!
次のネタいきましょう、次。

835 名前:デフォルトの名無しさん mailto:sage [02/09/20 22:24]
次のネタ候補
・FORTH や C, LISP, BASICなどのプログラミング言語のサブセット
・囲碁
>>533の前スレの未達成もののうち、このスレでも未達成のもの

特に言語ものは20行以下になったらとりあえず見せて欲しいなぁ。
サブセット言語で作った7行プログラムとか出てきたりして:-P

836 名前:デフォルトの名無しさん mailto:sage [02/09/21 00:50]
7行でC/C++コンパイラ作ってくだちぃ。


837 名前:デフォルトの名無しさん mailto:sage [02/09/21 01:03]
>>836
四則演算と表示くらいならできるかもしれないが、難しいだろうね。
つーか、>>836よ、インタプリタで良いから作ってみないか?

838 名前:デフォルトの名無しさん mailto:sage [02/09/21 01:23]
>>837
>四則演算と表示くらいなら...
マジで!?それともネタ?
冗談で言ったつもりなんだが…

>インタプリタで良いから...
技術のない漏れには作れません...


839 名前:デフォルトの名無しさん mailto:sage [02/09/21 02:32]
VTL系のBASICはどうなのかな?
オリジナルは768バイトなんでしょ?

840 名前:デフォルトの名無しさん mailto:sage [02/09/21 02:59]
マンセーうぜー言われるかもしれないが、やっぱり>>827は(・∀・)イイ! 



841 名前:デフォルトの名無しさん mailto:sage [02/09/21 05:50]
FORTHモドキ(逆ポーランド電卓か?)。オペレータは+-*/.のみ。

#include <stdio.h>
W[1000],*S=W,c,v;G(){c=getchar();}g(){v=0;do v=v*10+c-48;while((G(),c)-48<10U)
;return v;}main(){G();while(~c)c==45?G(),c-48>9U?v=*S--,*S-=v:(*++S=-g(),G()):
(c-48<10U?*++S=g():c==43?v=*S--,*S+=v:c==42?v=*S--,*S*=v:c==47?v=*S--,*S/=v:c-
46?c-32&&c-10&&printf("err\n"):printf("ok\n%d\n",*S--),G());}

842 名前:デフォルトの名無しさん mailto:sage [02/09/21 10:04]
既出ネタのチェックはしてから話題振ることにせんか?
 ・四則演算 >>5

843 名前:デフォルトの名無しさん mailto:sage [02/09/21 10:22]
多倍長整数、さらには有理数演算に対応しろと言ってみる。

844 名前:デフォルトの名無しさん mailto:sage [02/09/21 11:58]
・何かをグラフィック
・非常に便利な関数を7行で作成


845 名前:デフォルトの名無しさん mailto:sage [02/09/21 14:51]
>>842 ごめん、正直指摘間違いでは?、と始め思った。
つーか、>>841の勘違いですね。

四則演算はすでにあります。要求されたのは、
・FORTHのサブセット  あるいは
・四則演算のみ可能な C/C++ !!コンパイラ!!
ですよん。そして、
・多倍長整数、有理整数演算、浮動小数演算などに対応
が追加されますた。

846 名前:79文字で問題を出してみる(w mailto:sage [02/09/21 15:02]
問題:単なるクリックソートより早いqsort()互換のソート関数を79文字7行で記述せよ。

847 名前:846 mailto:sage [02/09/21 15:03]
>846にパッチ当て。
---問題:単なるクリックソートより早いqsort()互換のソート関数を79文字7行で記述せよ。
+++問題:単なるクイックソートより早いqsort()互換のソート関数を79文字7行で記述せよ。


848 名前:デフォルトの名無しさん [02/09/21 16:42]
>>835
いいだしっぺの法則

849 名前:デフォルトの名無しさん mailto:sage [02/09/21 17:22]
将棋作れ!

850 名前:デフォルトの名無しさん mailto:sage [02/09/21 17:47]
┃激┃し..┃く..┃ず┃れ┃て┃鬱┃だ.┃が┃
┣━╋━╋━╋━╋━╋━╋━╋━╋━┫
┃こ.┃れ┃で┃12┃行┃な.┃ん┃だ┃YO┃
┣━╋━╋━╋━╋━╋━╋━╋━╋━┫
┃  ┃  ┃  ┃  ┃  ┃  ┃  ┃  ┃  ┃
┣━╋━╋━╋━╋━╋━╋━╋━╋━┫
┃歩┃歩┃歩┃歩┃歩┃歩┃歩┃歩┃歩┃
┣━╋━╋━╋━╋━╋━╋━╋━╋━┫
┃  ┃角┃  ┃  ┃  ┃  ┃  ┃飛┃  ┃
┣━╋━╋━╋━╋━╋━╋━╋━╋━┫
┃香┃桂┃銀┃金┃王┃金┃銀┃桂┃香┃
┗━┻━┻━┻━┻━┻━┻━┻━┻━┛



851 名前:デフォルトの名無しさん mailto:sage [02/09/21 17:48]
激しくはずれなくてうれしいw

852 名前:デフォルトの名無しさん mailto:sage [02/09/21 17:49]
敵の歩なんかはどうしたらいいのさ?

┃歩┃歩┃歩┃歩┃歩┃歩┃歩┃歩┃歩┃
┣∨╋∨╋∨╋∨╋∨╋∨╋∨╋∨╋∨┫
とか?


853 名前:デフォルトの名無しさん mailto:sage [02/09/21 17:53]
ニフで昔あった将棋は

|歩v|歩^|

で表現していたな

コンピュータの思考ルーチンが激しく難しそうだ

854 名前:デフォルトの名無しさん [02/09/21 23:20]
前のスレッドにあった自動インデントプログラムを機能拡張・7行版にしてみました。
使用方は
 program.exe(仮称) 入力ファイル名 出力ファイル名
です。

#include <stdio.h>
FILE *s,*o;I,c,d;G(){return c=getc(s);}P(){c-10&&putc(c,o);}R(){putc(10,o);}T(t
){while(t-->0)putc(9,o);}S(p){d=1;P();while(~G()&&(P(),c!=41||--d))c-p||++d;}Q(
p){P();while(~G()&&(P(),c!=p))if(c==92||_ismbblead(c))P(G());}main(a,v)char**v;
{s=fopen(v[1],"r");o=fopen(v[2],"w");while(~G())c==63||c==58?R(),T(I),P():c==34
||c==39?Q(c):c==40?S(c):c=='{'?R(),T(I),P(),R(),T(++I):c=='}'?fseek(o,-1,1),P()
,R(),T(--I):P(),c==59&&(R(),T(I));}





855 名前:デフォルトの名無しさん mailto:sage [02/09/21 23:36]
>将棋
駒は数字で表せばいいじゃん。

王金銀桂香飛角歩 
+1+2+3+4+5+6+7+8 

玉金銀桂香飛角歩
-1-2-3-4-5-6-7-8

856 名前:デフォルトの名無しさん mailto:sage [02/09/21 23:55]
>>855
お前は数字を見て将棋だと言えるのか?

#現実問題、数字にでもしなければ不可能だとは思うが
#つーか数字にしても不可能だろ(w

857 名前:デフォルトの名無しさん mailto:sage [02/09/22 00:02]
囲碁の九路盤みたいに、将棋もサブセットがあればいいのだが・・・詰め将棋か?

858 名前:デフォルトの名無しさん mailto:sage [02/09/22 00:08]
詰め将棋だと駒が全部必要になってしまうのではさみ将棋はどうでしょう?

859 名前:デフォルトの名無しさん [02/09/22 00:09]
王 玉
金 キン
銀 ギン
桂 ケイ
香 車
飛 ヒシャ
角 カク
龍 リュウ
馬 ウマ
歩 フ
と  ト

でいけるんじゃ?

860 名前:デフォルトの名無しさん mailto:sage [02/09/22 00:13]
>>859
それだったら漢字+「符号」とか「色」で区別した方が扱いも容易
つーか、>>859だと駒の表現だけで2行くらい使ってしまうぞぅ



861 名前:デフォルトの名無しさん mailto:sage [02/09/22 00:14]
>>858
もはや別のゲームだが、面白いかもしれない。
コンピュータの思考ルーチンも簡単にかけるし。
よし、いっちょ作ってみるか。>>858が。

862 名前:デフォルトの名無しさん mailto:sage [02/09/22 00:15]
>>859
タマキン

863 名前:858じゃないけど mailto:sage [02/09/22 03:31]
はさみ将棋 現在9行+3文字 とりあえず動く版を作成

ルールは●○を縦横に移動させ、相手をはさむと取れます
ただし、辺を使ってはさんでも無効です
角をはさむのは正式ルールなのかわからなかったので、今のところ無効
移動方法は移動元(x,y)と移動先(m,n)の4整数で指定、左上が(1,1)
1 2 3 4 [RET]

コンピュータの思考ルーチンはまだなので、ランダムに移動します
今は、関数c()で動作を決めるようになっているので、どなたか作成をば!
変数vが移動元で変数zが移動先になってまつ。

int w[]={1,-1,12,-12},h[3],b[132],u=1,z,y,m,n,i=132,v,d=1;r(p,a,f,z){if(b[z=p+w
[a]]==(u^3)){d++;r(z,a,f);f?b[z]=0:0;}if(b[z]==3||!b[z])d=0;}o(x,y,m,n){d=0;z=x
+y*12;v=m+n*12;if((x!=m&&y!=n)||b[z]!=u||b[v]!=0)d=1;if(x==m){for(;y++<n;)d+=b[
x+y*12];}else if(y==n){for(;x++<m;)d+=b[x+y*12];}}c(){for(d=1;d;){for(i=132;i--
;)if(b[i]==2)v=i,i=0;z=rand()%132;o(v%12,v/12,z%12,z/12);}}main(x){for(;i--;b[i
]=z-11?z&&z-10&&i-12U<109?z-1?z-9?0:2:1:3:4)z=i%12;for(;;){printf("%d:%d %d\n",
u,h[1],h[2]);for(i=11;i++<131;)printf("・\0●\0○\0 \0\n"+b[i]*3);if(h[2]>7||h
[1]>7)break;if(u<2){scanf("%d%d%d%d",&x,&y,&m,&n);o(x,y,m,n);if(d&&puts("Err"))
continue;}else c();b[z]=0;for(i=4;i--;d?r(v,i,1):0)r(v,i,0),h[u]+=d;b[v]=u;u^=3;}}

864 名前:858じゃないけど mailto:sage [02/09/22 05:20]
>>863
あー、移動可能判定間違えてました。現在修正中です。

865 名前:858じゃないけど mailto:sage [02/09/22 05:48]
>>863
移動判定ミス修正、簡易思考ルーチン装備、やや縮めた版です。

int w[7]={1,-1,12,-12},b[132],u=1,z,y,m,n,i=132,v,d=1;r(p,a,f,z){b[z=p+w[a]]==3
-u?d++,r(z,a,f),f?b[z]=0:0:b[z]-1U>1?d=0:0;}o(x,y,m,n,p,a){d=b[v=m+n*12]+(b[a=z
=x+y*12]!=u||(x-m&&y-n)?1:0);for(p=x==m?y<n?2:3:x<m?0:1;!d&&a!=v;)d+=b[a+=w[p]]
;}c(j,k,s,f,g){s=-1;for(i=120;i--;d=0)for(j=120;b[i]==u&&j--;)for(o(i%12,i/12,j
%12,j/12),k=4;!d&&k--;d>s||d==s&&rand()%j<1?s=d,f=z,g=v:0)r(v,k,0);z=f;v=g;}
main(x){for(;i--;b[i]=z-11?z&&z-10&&i-12U<109?z-9?z-1?0:1:2:3:4)z=i%12;for(;;){
printf("%d:%d %d",u,w[5],w[6]);for(i=9;++i<120;)printf("・\0●\0○\0 \0\n"+b[i
]*3);if(w[5]>7||w[6]>7)break;u<2?scanf("%d%d%d%d",&x,&y,&m,&n),o(x,y,m,n):u>1&&
c();if(d&&puts("Err"));else{b[z]=0;for(i=4;i--;d?r(v,i,1):0)r(v,i,0),w[4+u]+=d;
b[v]=u;u^=3;}}}

866 名前:デフォルトの名無しさん mailto:sage [02/09/22 08:48]
>>865
相手のコマの上に持っていってエラーが出ても、相手のコマを消して続くぞ。

867 名前:858じゃないけど mailto:sage [02/09/22 16:47]
>>866
1 1 9 1 等では再現しませんでした・・・
よろしければ、棋譜(?)を教えてください。

868 名前:デフォルトの名無しさん mailto:sage [02/09/22 16:55]
>>867
俺は1 1 9 1 で一発再現。コンパイラ依存か?gccだけど
あと、1 1 91 1 とかも出来たりして、好きな場所にとばせるが、これは仕方ないか

869 名前:デフォルトの名無しさん mailto:sage [02/09/22 22:49]
だれか7行grepよろしく

870 名前:デフォルトの名無しさん mailto:sage [02/09/22 23:17]
#!/usr/local/bin/ruby
$pattern = ARGV.shift
while gets
  print if /#{$pattern}/
end



871 名前:デフォルトの名無しさん mailto:sage [02/09/22 23:18]
>>868

#!/usr/local/bin/perl
`grep @ARGV`;


872 名前:デフォルトの名無しさん mailto:sage [02/09/22 23:53]
>>871 せめて
$p=shift;$f=shift||"-";open H,$f;while(<H>){/$p/&&print $_}

perl grep.pl pattern file.txt
perl grep.pl pattern < file.txt
の両方を受け付けるように、という縛りをつけたらperlの短縮のいい例題になりますた。
見てのとおり初心者ですが、ここのスペースは要る、要らんとかいろいろあってなかなか
面白かったです。
まだパーサの改良ができるかもしれないです。
しかし、1行でこれだと7行は相当に死ねるな・・・・・・

873 名前:デフォルトの名無しさん mailto:sage [02/09/23 00:05]
while(<>){/$ARGV[0]/&&print $_}

<>の仕様が良く分かってませんでした。
道理で最初に試したのがうまく動かなかったわけだ。

874 名前:デフォルトの名無しさん mailto:sage [02/09/23 00:06]
あ、違った、こっちです。上のは動きませぬ。連投すま・・・・。
$p=shift;while(<>){/$p/&&print $_}

875 名前:871 mailto:sage [02/09/23 00:22]
まさかネタに突っ込まれるとは思わなかった。

>>874
>print $_;
print;
でいけます。


876 名前:871 mailto:sage [02/09/23 00:26]
$a=shift;/$a/&&print while(<>);


877 名前:デフォルトの名無しさん mailto:sage [02/09/23 01:01]
>>876
惜しい。
$a=shift;/$a/&&print while<>

でも始めから7行以内に収まる事が分かってるようなネタで
盛り上がるのは止めてもらえまいか。
どうせなら10行くらいから頼む。

878 名前:デフォルトの名無しさん mailto:sage [02/09/23 01:24]
>>822
つーかそれって単なる認証付きファイル検索なのでは?
認証して自分の所のファイル検索するCGIとそのクライアントのセット?
呼び出し用鯖も作れば余計なhtttpシーケンス省けるかな?


879 名前:871 mailto:sage [02/09/23 01:24]
>>877
while(<>) => while<>
うおぉ!そんな省略まで…。

>どうせなら10行くらいから
そうでつね。了解しました。


880 名前:デフォルトの名無しさん mailto:sage [02/09/23 02:06]
C言語でgrepを実装するのは正規表現を実装することだからそれなりに面白いと思われ。
どこまで行けるんだろ。



881 名前:デフォルトの名無しさん mailto:sage [02/09/23 04:18]
>>877
んじゃ、Cで作れ。
正規表現解析機を7行で実現しろって意味だったんだが、
perlとか糞Rubyに走るな

882 名前:877 mailto:sage [02/09/23 05:37]
>>881
>>869 さんかい? このスレは言語問わずだから、
このお題の出し方じゃPerlやRubyで応えられても文句言えないぞ(笑)。

俺は >>872 の段階で既に7行どころか1行に収まっているコードを
書き込み続けるのを止めて欲しかっただけなんだが、表現が悪かったかな。
「ネタ」ってのは「*Perlで* 7行grep」を意図してる。他の言語は知らんよ。

出されたネタに対しどの言語で組むかは自由だと思うが、
簡単に達成できる言語で応えるのは控えて欲しい。面白くないし。
反対に、PerlやRubyでも7行に縮めるのが難しそうなネタなら大歓迎。
JavaやJavaScriptでも言語の特色を活かした作品いっぱい出てるしね。


883 名前:デフォルトの名無しさん mailto:sage [02/09/23 07:30]
>>881
「正規表現解析機」て…。

884 名前:デフォルトの名無しさん mailto:sage [02/09/23 10:53]
なんだか私のせいで荒れたようで……。
申し訳ありませんでした。つい出来て嬉しくて書き込んでしまいました。
初心者だからといって、ここでは発表せず、脳内にとどめた方がよさそうですね。

885 名前:デフォルトの名無しさん mailto:sage [02/09/23 13:20]
厨だなぁ・・・
ほんと最近レベル落ちてるな。色々な意味で

886 名前:デフォルトの名無しさん mailto:sage [02/09/23 13:39]
お題:平安京エイリアン

887 名前:デフォルトの名無しさん mailto:sage [02/09/23 22:16]
しかし気にしすぎじゃない?。
まあ例えばprintfを7行でと言われても、結局テクニックの問題なんだし
単にそれが凄いのか凄くないのかって事なんだからさあ。確かにどうせなら
それを応用して7行使ったビックリするようなものが見てみたいけどね。
 ところでゲームといえば冷たい方程式系のシミュレーションはどうだろう?
アポロ13号とか、どっかのガス欠気味の人工衛星や探査機とかにコマンド送って
操作するような奴。それともまずは定番の月着陸からだろうか?

888 名前:デフォルトの名無しさん [02/09/24 17:23]
VTL系のBASICはどうなのかな?
オリジナルは768バイトなんでしょ?

889 名前:デフォルトの名無しさん mailto:sage [02/09/24 19:57]
>>888
過去ログ


890 名前:デフォルトの名無しさん [02/09/25 00:39]
HSPスレがなぜか姉妹スレ化してる…
game.2ch.net/test/read.cgi/gamedev/1005332663/l50



891 名前:デフォルトの名無しさん mailto:sage [02/09/25 00:41]
game.2ch.net/test/read.cgi/gamedev/1005038280/l50

892 名前:デフォルトの名無しさん mailto:sage [02/09/25 01:05]
>>889
そもそも私(>>839)のコピペ。
でネタ自体は>>11で既出だったらしい。
ちなみに前スレや>>612>>626のは予約語からして普通のBASIC
じゃないかな?それともなにか見逃してる?
もっと中間コード風でGAMEIIコンパイラみたいな奴。







[ 続きを読む ] / [ 携帯版 ]

前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧](;´∀`)<349KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef