分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.youkuaiyun.com/jiangjunshow
也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!
【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】
组合模式听说去很玄乎,其实也并不复杂。为什么?大家可以先想一下数据结构里面的二叉树是怎么回事。为什么就是这么一个简单的二叉树节点既可能是叶节点,也可能是父节点?
typedef struct _NODE{ void* pData; struct _NODE* left; struct _NODE* right;}NODE;
那什么时候是叶子节点,其实就是left、right为NULL的时候。那么如果它们不是NULL呢,那么很明显此时它们已经是父节点了。那么,我们的这个组合模式是怎么一个情况呢?
typedef struct _Object{ struct _Object** ppObject; int number; void (*operate)(struct _Object* pObject);}Object;
就是这么一个简单的数据结构,是怎么实现子节点和父节点的差别呢。比如说,现在我们需要对一个父节点的operate进行操作,此时的operate函数应该怎么操作呢?
void operate_of_parent(struct _Object* pObject){ int index; assert(NULL != pObject); assert(NULL != pObject->ppObject && 0 != pObject->number); for(index = 0; index < pObject->number; index ++) { pObject->ppObject[index]->operate(pObject->ppObject[index]); }}
当然,有了parent的operate,也有child的operate。至于是什么操作,那就看自己是怎么操作的了。
void operate_of_child(struct _Object* pObject){ assert(NULL != pObject); printf("child node!\n");}
父节点也好,子节点也罢,一切的一切都是最后的应用。其实,用户的调用也非常简单,就这么一个简单的函数。
void process(struct Object* pObject){ assert(NULL != pObject); pObject->operate(pObject);}
给我老师的人工智能教程打call!http://blog.youkuaiyun.com/jiangjunshow
