Ожидаемый тип: String, Фактический тип [[Char]] сообщение об ошибке в Haskell

Я работаю над реализацией настольной игры "Отелло" на Haskell и все еще в начале процесса. В настоящее время я пытаюсь создать функцию, которая будет отображать доску. В данный момент я просто пытаюсь заставить функцию выводить значение координаты каждой ячейки. Моя идея состоит в том, что я могу пройти через каждую строку, а затем через каждую ячейку и вывести значение каждой. Затем я вызываю эту функцию в main и выводю плату в виде строки.

Однако у меня возникли проблемы с конкатенацией строк, и я обнаружил ошибку "Ожидаемый тип: String, Фактический тип: [[Char]].

Я знаю, что в Haskell String - это, по сути, псевдоним для [Char], но я не понимаю, почему я получаю [[Char]], когда использую функцию "++".

showGameState :: GameState -> String
showGameState g =
      let boardStart = (1,1)
      in drawBoard boardStart (board g) (size $ board g)

//the standard board is size 8*8
//here im trying to recursively call the drawBoardRow function increasing the row each time
drawBoard :: (Int, Int) -> Board -> Int -> String
drawBoard pos b len =
      let string = ""
      in if len > 0
              then string ++ (drawBoardRow pos (size b) : [drawBoard (fst pos, snd pos +1) (b) (len - 1)])
              else return string


//callig the drawBoardCell function recursively increasing the column position each time
drawBoardRow :: (Int, Int) -> Int -> String
drawBoardRow pos len =
      let string = ""
      in if len > 0
              then string ++ (drawBoardCell pos : [drawBoardRow(fst pos + 1, snd pos) (len - 1)]) ++ "\n"
              else return string


//At this stage i simply want to add each the coordinate of the cell the string containing
//the row
drawBoardCell :: (Int, Int) -> String
drawBoardCell pos =
      let string = ""
      in return (string ++ " " ++  show(fst pos) ++ show(snd pos) ++ " ")

В идеале я хочу, чтобы эта функция выводила это:

11 21 31 41 51 61 71 81
12 22 32 42 52 62 72 82
13 23 33 43 53 63 73 83
14 24 34 44 54 64 74 84
15 25 35 45 55 65 75 85
16 26 36 46 56 66 76 86
17 27 37 47 57 67 77 78
18 28 38 48 58 68 78 88

Извините, если мой код плохо читается или мои идеи неясны, я все еще пытаюсь изучить основы Haskell. Заранее благодарим за ваше время и помощь.

2 ответа

Решение

Это потому что

(drawBoardCell pos : [drawBoardRow(fst pos + 1, snd pos) (len - 1)])

это [String], а не String, и вы не можете добавить String к [String].
(drawBoardCell а также drawBoardRow производить Stringс, так [drawBoardRow ...]это [String], так что все это тоже [String].)

Вам нужно придерживаться ++.

Также похоже, что вы используете let а также returnкак если бы это был какой-то другой язык программирования, который вы уже знаете.
Если вы знаете какой-то другой язык программирования, сейчас самое время забыть об этом.

Тебе не нужно return вообще здесь, и большинство ваших letне служат никакой цели.

Мой собственный взгляд на новичок будет выглядеть так:

drawBoard :: (Int, Int) -> Board -> Int -> String
drawBoard _ _ 0 = ""
drawBoard pos@(x,y) b len =
  drawBoardRow pos (size b) ++ drawBoard (x, y + 1) b (len - 1)

drawBoardRow :: (Int, Int) -> Int -> String
drawBoardRow _ 0 = ""
drawBoardRow pos@(x, y) len =
  drawBoardCell pos ++ drawBoardRow(x + 1, y) (len - 1) ++ "\n"

drawBoardCell :: (Int, Int) -> String
drawBoardCell (x, y) = " " ++  show x ++ show y ++ " "

Это потому, что вы используете returnвроде это Java или что-то в этом роде. Избавьтесь от всех своихreturnВы показали нам здесь и попробуйте еще раз, и это должно сработать.

Другие вопросы по тегам