1 :
名無しさん@お腹いっぱい。:
Part2やるほど需要があったのか?
ま、それは兎も角どうせならPHPとかも可にして欲しかった。
3 :
1:2001/05/02(水) 19:20 ID:???
需要ないけどいいの。少人数でやってくから。
PHPの回答も大歓迎だよー。どんどん参加してくれー。
5 :
前スレ39:2001/05/03(木) 12:01 ID:JPrRLY3o
前スレ 48 でちょっと検証
or $count > 100 and index("0987654321", $count)>=0 #くだり賞
ではカウンタは普通先頭に0が来ないし 3210 などにも対応させるために
or $count > 100 and index("9876543210", $count)>=0 #くだり賞
にしたほうがいいかと思われ。
しかし index は普段使わなかっただけに
こういう便利な使い方があるんかと素直に感心した。
6 :
前48:2001/05/03(木) 20:41 ID:.kTr8MpA
>>5 >or $count > 100 and index("9876543210", $count)>=0 #くだり賞
>にしたほうがいいかと思われ。
あ、そっか。
何も考えずにのぼり賞の逆にしただけだったからなぁ。
>こういう便利な使い方があるんかと素直に感心した。
これ思いついたので解答してみる気になったという...
実用スクリプトで役に立ちそうな場面はちょっと思いつかないけど。
つけたし:
前スレ48のぞろ目の正規表現、
or $count =~/^(\d+)\1+$/
に変更したら、「121212」とか「123123」とかも弾ける。
7 :
むぎ茶 :2001/05/04(金) 06:26 ID:???
ほえほえ#password
9 :
9:01/09/02 19:21 ID:ixHN2n4k
久々に<お題>
1,2,3,4,5,6,7,8,9(数字の並びは固定)がある。
これらの数の間に+、−、何も入れないという演算子をいれて、計算
する。そして、計算結果が100になる組み合わせを、すべて表示する
プログラムを作成せよ。100になるのは、11通りのはず。
http://piza2.2ch.net/test/read.cgi?bbs=tech&key=998808627 からのパクリだけど、Perlでやったらどうなる?
ちなみに俺の考えた解はこれ。
corn.2ch.net/test/read.cgi?bbs=php&key=988718702&st=35&to=35&nofirst=true
面白そうだけど全然解法が思いつかん (死
碌でもないコードしか思いつかない...。
---------------------------
ハッシュ(の文字列表現)利用。
foreach my $i (grep{!($_ % 3)} 0..3**9){
@h{1..9} = map{('','-','+')[($i /= 3) % 3]} 1..8;
print %h,"\n" if eval join("",%h) == 100;
}
---------------------------
単純な再帰で虱潰し。
sub r{
my($str, $num) = @_;
for my $op ('', '-', '+'){
my $exp = join($op, $str, $num);
$num != 9 ? r($exp, $num + 1)
: eval($exp) == 100 ? print "$exp\n" :next;
}
}
r("1", 2);
12 :
名無しさん@お腹いっぱい。:02/01/03 12:45 ID:1F/Y4C+i
あげてみようか、、
ey7u4eyreyryryryyyy
っっっっっっっっっっp