人工智能导论(C实现一个简单的推理机)

用C++实现一个简单的推理机—动物推断

// 简单推理机_动物推断,以鸡、猫、蛇和蜥蜴为例,构建一个简单的动物推断推理机

#include "stdafx.h"
#include <iostream>
#include <string>
#define Chicken 0x01	//鸡		0010
#define Cat     0x00	//猫		0000
#define Snake   0x03	//蛇		0001
#define Lizard  0x04	//蜥蜴	    0101
using namespace std; 
unsigned char result = 0;

typedef struct Rule{
	char *info;		//规则信息
	Rule *pYes;		//匹配到的下一个规则
	Rule *pNo;		//未匹配到的下一个规则
	int pos;		//该规则的位置
}Rule;
int CheckRule(char *s, char *info){
	if(0 == strcmp(s, "Yes"))
		return 1;
	else
		return 0;
}

//定义规则结构
void MatchRules(char *s, Rule *match){
	if(!s || !match)
		return;

	printf("%s ?",match->info);
	printf("\n");
	char str[50] ;
    std::cin>>str;
	s=str;


	//规则是否匹配上
	if(CheckRule(s, match->info) > 0){
		//记录位置
		if(NULL==match->pYes)
		{	result = match->pos;
			return;
		}
		MatchRules(s, match->pYes);
	}
	else
	{
		//未匹配上
		if(NULL==match->pNo){
			result = match->pos-1;
			return;
		}
		MatchRules(s, match->pNo);
	}
}

int _tmain(int argc, _TCHAR* argv[]){
//	提示
	printf("Type into 'Yes' if the condition is satisfied, anything else if not.\n");

//输入规则
	Rule *rule1=new Rule;
	rule1->info="ColdBlood";
	rule1->pos=3;

	Rule *childrule1=new Rule;
	childrule1->info="HasFeather";
	childrule1->pos=1;

	Rule *childrule2=new Rule;
	childrule2->info="HasLeg";
	childrule2->pos=4;
	childrule2->pYes=NULL;
	childrule2->pNo=NULL;

	rule1->pNo=childrule1;
	rule1->pYes=childrule2;

	Rule *childrule3=new Rule;
	childrule3->info="CanFly";
	childrule3->pos=2;
	childrule3->pYes=NULL;
	childrule3->pNo=NULL;

	childrule1->pYes=childrule3;
	childrule1->pNo=NULL;



while(1){
	//输入内容
	char *temp="start";
	//推理
	MatchRules(temp, rule1);
	//输出结果
	switch (result)  {
    case Chicken:  
        printf("鸡!\n");     
        break;  
    case Cat:  
        printf("猫!\n");  
        break;  
    case Snake:  
        printf("蛇!\n");  
        break;  
    case Lizard:  
        printf("蜥蜴!\n");  
        break;  
    default:  
        printf("其他!\n");  
        break;  
    }  
}
	return 0;
}

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值