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

lunlumo #7560() [ Scala ] Rating0/0=0.00
ソートを掛ける方法で。
class CGhostLeg(g:List[Int]) { val s:List[Int] = g.sort { (a,b) => a < b } var p:List[List[Boolean]] = List() def create:CGhostLeg = { def _calc(c:List[Int],r:Tuple2[List[Int],List[Boolean]]):Tuple2[List[Int],List[Boolean]] = c match { case List() => r case h::List() => (r._1+h,r._2) case h::t => h.compare(t.head) match { case p if p > 0 => _calc(c.slice(2).asInstanceOf[List[Int]],(r._1+c.apply(1)+h,r._2+true++(t match { case h::List() => List(); case _ => List(false) }))) case _ => _calc(t,(r._1+h,r._2+false)) } case _ => r } def _step(c:List[Int]):Unit = { val n = _calc(c,(List(),List())) p = n._2::p if (!n._1.zip(s).filter { d => d._1 != d._2 }.isEmpty) _step(n._1) } _step(g) this } def print:Unit = { def _join(d:String,l:List[String]):String = l.head + l.tail.foldLeft("") { (s,e) => s + d + e } println(_join(" ",s.map { e => e.toString })) p.foreach { l => println(_join("|",""::(l.map { e => e match { case true => "-"; case _ => " " } })+"")) } println(_join(" ",g.map { e => e.toString })) } } object GhostLeg { def main(args:Array[String]):Unit = { try { var g:List[Int] = args.length match { case 0 => List(3,5,2,4,0,1) case _ => args.toList.map { s => s.toInt } } (new CGhostLeg(g)).create.print } catch { case e => e.printStackTrace } } }Rating0/0=0.00-0+
[ reply ]