Haskell
久しぶりにcodeforces. この問題 を解いてみた。 import Data.List main = do cs <- getContents case answer.map read.take 6.words $ cs of [a,b,c,d] -> putStrLn (show a ++ " " ++ show b) >> putStrLn (show c ++ " " ++ show d) [] -> putStrLn "-1" …
バックトラックアルゴリズムを書いたことないなあ、と思い、 n-Queen問題に、C言語で挑戦してみた。 方針はわかるのだけれど、 変数の変更の様子を追うのがしんどくてしんどくて..... 挫折した。 こんなことではダメなので、もっとちゃんと考えてから再挑戦…
wxHaskellで、エディットコントロールに入力した文字列を取り出すにはどうしたら良いのか調べていました。 Hoogleでは情報がヒットしないので調べ辛い.... 色々調べた結果、 textDialogが使えそう。 textDialog :: Window a -> String -> String -> String -…
今年一番最初に使った言語はJavaでした。 副作用にまみれそうです笑 でも、Eclipseを使っていて思うのは、補完機能がすごい。 というか、javaで開発する人は、Eclipseなしでは一気に生産性が落ちたりしないのでしょうか? そう思うくらい便利。あと、昨年末…
昨日から2週間弱の短い冬期休暇に入りました 明日から北海道に旅行です。 準備も先ほど終わり、明日を待つのみ。 出かける前に何か軽いコーディングをしようと思い、TopCoderに慣れてみることにした。 練習場のような場所があり、ある程度の難易度の問題が出…
昨日からしばらくwxHaskellを触っています。最初、GUIパーツの配置方法がわからずに悩んでいたので、 ここに覚え書き。パーツはそれぞれ(ボタンやエディットボックスなど)、 IO型に包まれて返されますなので、 btn <- button p [text := "ほげ" , on comma…
この間、OpenGLを使った記事を書きましたが、 wxHaskellでは、よく見るようなGUIパーツを簡単に使う事が出来るようです。 しかし、このFedoraに入れようとすると失敗してしまい、 以来ずっとOpenGLいじくり回していました。 HaskellWikiをちゃんと読んでみる…
一つ前の記事で書いた方法ではタイムオーバーになってしまう。func_hsさんの記事を読んで、 ByteStringを使う方法があることを思い出す しかし、初めて使うので思考錯誤の末、 あまり意味がないように感じるけど、次のようなものを書いてみた import Data.Li…
一昨日codeforcesで開催された問題を昨日解いていたのですが。 Haskellで書いたものはタイムオーバーになってしまいました。問題はこちら模範解答?のようなものがcodeforcesに挙げられていたので読んでみた すると、私が考えた通り、aの要素でソートしてか…
何かをまた新しく作り始めたく、 スケジュールアプリでも作ろうかと思い立つ。 スケジュールなので、データを保存する必要があります。 そして、保存したデータを読み出す必要がある。 パーサが要る。そういえば以前、Peggyなるパーサがリリースされていまし…
DXライブラリとHSPでしか まともにGUIアプリを作成したことのない私が、 HaskellでOpenGLをいじる、不定期連載。 OpenGLがそもそもどういうものなのか、そこから知る必要がありましたが、その際、次の本が大変参考になったので紹介しておきます。 「OpenGL入…
Haskellは、Data.Arrayモジュールを用いてデータを配列のように扱うことができる。 が、書き換えはコストが高いために苦手。 だからデータ参照などにのみ使用した方が良い。 ならばそうしましょう。Data.Arrayを利用して、多次元配列問題を解く! 手始めには…
以前に一度Data.Arrayについて記事を書いたことがあったが、 その時は基本的な関数について触れただけで終わった気がする。今回は、二次元配列を触ってみた。とりあえず、1桁の数で作られたテーブルから値を読み取る。ソースコードは以下のとおり import Dat…
試験勉強の合間、Haskellでちょっと遊んでみようと思い、40分ほど遊んでみよう。 というわけで、簡便なbrainf*ckを組んでみた。 []の複数仕様には対応していないし、 外部からの入力も一桁の数値だけですが。 解析と実行が同時並行なので、 タプル形式で読み…
数値解析の講義で扱った内容。 今まで、3点から二次多項式を求める場合、 Gauss-Jordan法を用いて係数を決定して、 導かれた多項式に対して 値を適用することで値を出していましたが、 そんな面倒なことはしなくてもいいようです。とりあえず、簡単のため、…
今日はHaskellでの GHC拡張の一つ、ViewPatternを使ってみました。 更に、それをC言語から利用してみます。まずはファイルの先頭に以下の拡張宣言を {-# LANGUAGE ViewPatterns #-} これでViewPatternsを利用可能になりました。ぱっとは面白い関数が思いつか…
今日はcodeforcesの問題を夕方と帰宅後、合わせて3問解きました。 そのうちの一問、こちら 捻ったようなアルゴリズムも不要で、 ちゃんと書けばちゃんと動いてくれる問題。 問題の背景を考えるとちょっと面白かったです。 10進数→2進数、 2進数→10進数の関数…
問題はこちら単純なアルゴリズムはすぐに完成しましたが、 残念なことに、以下のコードではタイムオーバー.... どうするのがよいでしょうか。 group関数で一まとめにしてやると早くなるのかな与えられたデータセットが100000個の-1だから... きっとこれは畳…
久しぶりに書きます。 なんとかして時間をつくらないと、何にも手をつけられない状態です。 明日は解析学の試験ですが、 一段落したのでcodeforcesの問題を解いてみました問題はこちら単純に、combinationを使ってやればいけそうです。 combinator::nCkなど…
昨日考えていた問題を解くことが出来ました!問題はこちら両隣との差が1となるように円を作れ、という問題 差が1で且つ、一番小さい値の両隣は常に自身より1大きい値だよなあ、と、ここまでは気づいたのですが、 どうやったらそれを落とし込めるかでつまづい…
ページビューが、今ちょうど66666!!状態保存(変数保存)の方法が、Stateモナド以外にあると聞いて。 IORefで行えるようです。 いろんなサイトみてたらちょくちょく見かけたので、 どのようなものか、触ってみた import Data.IORef main = do n <- newIORe…
ここ一カ月は、 HaskellのGUIまわりを触りつづけようと思ってます。 半年くらい前からHaskellでノベルゲームエンジンを作る! と思っているけれど、やはりGUIってどうしても面倒なイメージがあり、腰が重い。 まずね、日本語表示ができないです これが一番の…
Haskellだとこの手の繰り返し処理はとても簡単ですね。 明日の講義の演習課題として出されていたのですが、 答えがあっているかどうかの確認用に書きました。 以下の例では、 手計算では6回ほど繰り返さないと答えが出力されませんね... import Control.Mona…
こちらも、 「プログラミングコンテストチャレンジブック」にあった問題です。 整数nと、いくつかの数字列が与えられたときに、 与えられた数字列から重複を許して4つ値を取り出したとき、 その和がnになるかの姓があるかどうかという問題がありますまずは素…
今日は、 「プログラミングコンテストチャレンジブック」で取り扱っているPOJの問題をHaskellで解いてみました。問題はこちら import Data.List main = do nls <- getLine print $ findAnswer (ls nls) [] where ls = map read.tail.words findAnswer :: Int…
Haskellで今日も、簡単なものを解いてみた。 が、なぜかruntime errorとかで通らない手元でやるとどれも一瞬で答え出るし、環境もそれほどよくはないから問題はないはずなんだけど問題はこちら import Control.Monad main = do n <- getContents forM_ (map …
二つ前の記事で、 解いたと思っていた問題。 今日通してみると、誤っていることが判明しました。 なので素直に書きなおしてみた。 main = do nab <- getLine let (n:a:b:_) = map read $ words nab print $ length $ filter ((==n-1).f) [(x,y) | x <- [a..n…
機能に引き続き、Yesodに触ってみよう! ということで。 Yesodの使い方を紹介しているページを見ていると、Blogを取り扱った記事を発見! HaskellでBlog作れたら絶対楽しいに違いない! というわけで。 兎にも角にも写経して挙動を確認してみた。 実行結果は…
func_hsさんが放送していたのをきっかけに、codeforcesの問題に久々に挑戦してみた。 問題文はこちら見た感じ、Haskellが得意そうな問題です main = do nab <- getLine let (n:a:b:_) = map read $ words nab print $ findAnswer (take n $ repeat 1) a b fi…
今日はweb framework,Yesodに触りました。 今までFedoraでもwindowsでもなかなかうまいこといかず行き詰まっていたのですが、今日何気なしに yesod --help とタイプしたらURLが表示されたり、使い方が表示されたりしたのでやってみた。 helpコマンド便利です…