设计L系统数据结构(C)
我正在尝试设计数据结构,用于在C中实现L-System重写引擎,我似乎无法得到任何地方:(.
我需要存储一串符号(字符).有几种类型的符号(由LSystem的字母表指定).假设我们有类型“A”,“B”,“C”.现在每种类型的符号都可以有不同的参数.例如,类型A的符号将具有一些距离,符号B将具有角度. C符号没有参数.然后字符串看起来像“ABABC”. 然后我需要遍历字符串并执行一些也连接到每种符号类型的操作. “A”可以表示“绘制’距离’长度线”(距离是A的参数),B“转’角’度’和C完成绘画. 我尝试为每个符号类型(类SymbolA,类SymbolB,类SymbolC)设置类Symbol和子项,但我不知道如何创建字符串.我想避免类型转换和类似的东西. 是否有人有类似的问题或有想法可以帮助我,拜托? 解决方法
如果你想实现像完整的L系统一样复杂的东西,我建议使用比C更高级的语言,比如
Python或Common Lisp.然后,您可以分析整个代码段并实现C/C++中的速度瓶颈.
很久以前,我使用Common Lisp实现了混沌理论和分形课程的L系统.这不是太难做 – 只是使用了一个符号列表.我一直试图找到它的代码,但它已经超过7年,所以到目前为止没有运气. 无论如何,这对我来说似乎更合理.即使您使用高级语言进行缓慢的实现,它也会让您更好地了解如何在C中实现它,这需要更多的开发人员时间来完成. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |