解答・コメントを送る方法
コメントを送るには2つの方法があります。
- 匿名でコメントを書くログインせずにコメントを書くことができます。 名前は「匿名」となります。
- アカウントを作成してコメントを書くアカウントを作成すると、記名での投稿ができます。 また、プロフィールページが作成され、 簡単なプロフィールや 統計情報が表示されるようになります。
投稿ボタンを押す前に以下の文章を確認してください
- 当サイトへの投稿は クリエイティブ・コモンズ・ライセンス BY(表示)および、その解釈に同意するものとみなされます。各ページには下のようにライセンス表示が行われます。
- あなたの投稿したコード・コメント・トピックが再利用・添削されることを望まない場合は、投稿をお控えください。
- 自分が書いていない、ウェブサイトや書籍などからの無断コピーは著作権の侵害です。著作権者の了解を得るか、自分で0から書いてください。
- 著作権の侵害、名誉毀損、など投稿内容に問題がある場合、削除することがあります。
- これらのことにあなたはあらかじめ同意したものとみなされます。
Post comment
Post a comment to the following challenge:
小町算
(Nested
Flatten)
As a reply to the following comment: yuin: パーサコンビネータでパーサを作ってナイー...(#4735) [show]

yuin
#4735()
[
Scala
]
Rating0/0=0.00
パーサコンビネータでパーサを作ってナイーブに。 解答は101個です。
import scala.util.parsing.combinator.{Parsers, ImplicitConversions, ~, mkTilde} import scala.util.parsing.combinator.syntactical.StdTokenParsers import scala.util.parsing.combinator.lexical.StdLexical object Komachi extends StdTokenParsers with Application{ type Tokens = StdLexical ; val lexical = new StdLexical lexical.delimiters ++= List("+","-", "*", "/") def expr = term*("+" ^^ {(x: double, y: double) => x + y} | "-" ^^ {(x: double, y: double) => x - y}) def term = factor*("*" ^^ {(x: double, y: double) => x * y} | "/" ^^ {(x: double, y: double) => x / y}) def factor: Parser[double] = numericLit ^^ (_.toDouble) ((List(List[String]())) /: List.make(8, List("+", "-", "*", "/", ""))){ for(i <-_; j <-_) yield j::i }.foreach{fs => val s = (new StringBuilder("1") /: (2 to 9)){(s,i) => s.append(fs(i-2)).append(i) }.toString if(expr(new lexical.Scanner(s)).get == 100.0) println(s) } }Rating0/0=0.00-0+
[ reply ]