首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将二叉树的字符串表示形式读入树中?

如何将二叉树的字符串表示形式读入树中?
EN

Stack Overflow用户
提问于 2021-10-26 21:43:39
回答 1查看 151关注 0票数 2

我有以下代码,它接受输入作为ex中给出的示例,并创建一个具有给定类型的树:

代码语言:javascript
复制
data QA = Leaf String | Question QA String QA

ex :: QA
ex = (Question 
       (Question (Leaf "Marie Curie") "Is she a scientist?" (Leaf "Queen Elisabeth II"))
       "Is she from Europe?"
       (Question (Leaf "Marilyn Monroe") "Is she an actress?" (Leaf "Hilary Clinton")))

showQa :: QA -> String 
showQa (Leaf x) = "(" ++ x ++ ")"
showQa (Question left x right) = "(" ++ x ++ showQa left ++ showQa right ++ ")"

instance Show QA where
  show = showQa

然后,我使用showQa函数将树转换为字符串,以便能够将其存储在文件中,输出如下字符串:

代码语言:javascript
复制
"(Is she from Europe?(Is she a scientist?(Marie Curie)(Queen Elisabeth II))(Is she an actress?(Marilyn Monroe)(Hilary Clinton)))"

问题是,当我再次从文件中读取字符串时,如何将这个字符串转换为原始类型的树。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-03-15 18:00:53

使QA成为显示和读取的实例

代码语言:javascript
复制
data QA = Leaf String | Question QA String QA deriving (Show, Read)

您可以通过这种方式摆脱showQa,只需调用QA类型的显示即可。读书也是如此。

当你写到文件时你可以

代码语言:javascript
复制
writeFile "[FileName].qa" (show ex)

" ex“应该是QA类型的名称,在您的例子中称为ex

从文件中读取,只需使用readFile并读取结果:

代码语言:javascript
复制
fileReader = do
    content <- tryIOError (readFile "[FileName].qa")
    case content of
        Left e  -> do
            return (ex) --In case of reading file goes wrong
        Right r -> do 
            return (read r)
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69730321

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档