亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 推理機view.cpp

?? 一個基于H.wang的謂詞演算公式的機器證明的vc實現
?? CPP
字號:
// 推理機View.cpp : C推理機View 類的實現
//

#include "stdafx.h"
#include "推理機.h"
#include "推理機Doc.h"
#include "inDlg.h"
#include "help.h"
#include "mystack.h"
#include "推理機View.h"
#include "FormulaTree.h"
#include "Illation_machine.h"
#include "myset.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// C推理機View

IMPLEMENT_DYNCREATE(C推理機View, CScrollView)

BEGIN_MESSAGE_MAP(C推理機View, CScrollView)
	// 標準打印命令
	ON_COMMAND(ID_FILE_PRINT, &CScrollView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, &CScrollView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, &CScrollView::OnFilePrintPreview)
	ON_COMMAND(ID_32771, &C推理機View::On32771)
	ON_COMMAND(ID_32772, &C推理機View::On32772)
	ON_COMMAND(ID_32777, &C推理機View::On32777)
END_MESSAGE_MAP()

// C推理機View 構造/析構

C推理機View::C推理機View()
{
	// TODO: 在此處添加構造代碼
	f=0;
	m_pCurFont=new CFont;
	m_pCurFont->CreateFont(20,0,0,0,400,FALSE,FALSE,0,ANSI_CHARSET,OUT_DEFAULT_PRECIS,CLIP_DEFAULT_PRECIS,DEFAULT_QUALITY,DEFAULT_PITCH&FF_SWISS,_T("Aerial")); 
	height=20;
}

C推理機View::~C推理機View()
{
}

BOOL C推理機View::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: 在此處通過修改
	//  CREATESTRUCT cs 來修改窗口類或樣式

	return CScrollView::PreCreateWindow(cs);
}

// C推理機View 繪制

void C推理機View::OnDraw(CDC* pDC)
{
	C推理機Doc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	if (!pDoc)
		return;

	// TODO: 在此處為本機數據添加繪制代碼
	CFont *pold;
	int k,i=20;
	pold=(CFont *)pDC->SelectObject(m_pCurFont);
	pDC->SetTextColor(color);
	pDC->SetBkMode(TRANSPARENT);
	proof_procedure.MakeEmpty();
	if(f==0)return;
	if(formu.GetLength()==0){ pDC->TextOutW(20,20,_T("輸入為空!")); return; }
	char *str=new char[formu.GetLength()+1];
	for(k=0;k<formu.GetLength();k++) str[k]=(char)formu[k];		str[k]='\0';
	if(!IsLegal(str,0,strlen(str)-1)){ pDC->TextOutW(20,20,_T("公式不合法!")); return; }
	proof_procedure.push(formu);
	Illation_machine m(str);
	proof_procedure.push(_T("推理證明過程為"));
	int istrue=m.Illation(proof_procedure);
	if(f==1){
		pDC->TextOutW(20,20,formu);
		if(istrue==1){ pDC->TextOutW(20,20+height,_T("為重言式")); return; }
		FormulaTree<char> ft(str);
		char *cnf=ft.ToCNF();
		int flag=SimplifyCnf(cnf);
		if(flag==-1){ pDC->TextOutW(20,20+height,_T("為矛盾式")); return;}
		else{
			pDC->TextOutW(20,20+height,_T("合取范式為"));
			CString temp(cnf);
			pDC->TextOutW(20,20+2*height,temp);
		}
		delete []cnf;
	}
	else if(f==2){
		proof_procedure.push(_T("析取范式為"));
		pDC->TextOutW(20,20,formu);
		if(istrue==1){ pDC->TextOutW(20,20+height,_T("為重言式")); return; }
		FormulaTree<char> ft(str);
		char *dnf=ft.ToDNF();
		int flag=SimplifyDnf(dnf);
		if(flag==-1){ pDC->TextOutW(20,20+height,_T("為矛盾式")); return;}
		else{
			pDC->TextOutW(20,20+height,_T("析取范式為"));
			CString temp(dnf);
			pDC->TextOutW(20,20+2*height,temp);
		}
		delete []dnf;
	}
	else if(f==4){
	
		if(istrue==1){
			while(!proof_procedure.IsEmpty()){
				pDC->TextOutW(20,i,proof_procedure.top());
				proof_procedure.pop();
				i+=height;
			}
		}
		else{
			pDC->TextOutW(20,i,proof_procedure.top());i+=height;
			pDC->TextOutW(20,i,_T("該命題不成立"));i+=height;
			
		}
	}
	delete []str;
	
}

void C推理機View::OnInitialUpdate()
{
	CScrollView::OnInitialUpdate();

	CSize sizeTotal;
	// TODO: 計算此視圖的合計大小
	sizeTotal.cx =5000;
	sizeTotal.cy = 100000;
	SetScrollSizes(MM_TEXT, sizeTotal);
}


// C推理機View 打印

BOOL C推理機View::OnPreparePrinting(CPrintInfo* pInfo)
{
	// 默認準備
	return DoPreparePrinting(pInfo);
}

void C推理機View::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: 添加額外的打印前進行的初始化過程
}

void C推理機View::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: 添加打印后進行的清理過程
}


// C推理機View 診斷

#ifdef _DEBUG
void C推理機View::AssertValid() const
{
	CScrollView::AssertValid();
}

void C推理機View::Dump(CDumpContext& dc) const
{
	CScrollView::Dump(dc);
}

C推理機Doc* C推理機View::GetDocument() const // 非調試版本是內聯的
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(C推理機Doc)));
	return (C推理機Doc*)m_pDocument;
}
#endif //_DEBUG


// C推理機View 消息處理程序

void C推理機View::On32771()
{
	// TODO: Add your command handler code here
	inDlg in;
	in.construct(formu);
	in.DoModal();
	UpdateData(FALSE);
	if(in.f==5)Invalidate();
	else{
		f=in.f;
		formu=in.form();
		Invalidate();
	}
	

}

void C推理機View::On32772()
{
	// TODO: Add your command handler code here
	CFontDialog dlg;
	if(dlg.DoModal()==1){
		delete m_pCurFont;
		m_pCurFont=new CFont;
		m_pCurFont->CreateFont(dlg.GetSize(),0,0,0,dlg.GetWeight(),dlg.IsItalic(),dlg.IsUnderline(),dlg.IsStrikeOut(),ANSI_CHARSET,OUT_DEFAULT_PRECIS,CLIP_DEFAULT_PRECIS,DEFAULT_QUALITY,DEFAULT_PITCH&FF_SWISS,dlg.GetFaceName());
		color=dlg.GetColor();
		height=dlg.GetSize();
	}
	Invalidate();
}

bool C推理機View::IsLegal(char *s,int start,int end){
		int count=0,flag=0;
	//判斷括號是否匹配
	for(int i=start;i<=end;i++)
		if(count<0)
			return false;
		else if(s[i]=='('){
			count++; flag=1;
		}
		else if(s[i]==')')
			count--;
	//不匹配返回假
	if(count!=0)return false;
	//flag==0意味著式中未出現括號,則只可能呈形!!!a,a+b,a*b,a>b,a=b,!!!!!a+!!!b等情況
	if(flag==0){
		int i=start;
		while(s[i]=='!')i++;
		if(Isalpha(s[i]))
			i++;
		else
			return false;
		if(i==end+1)return true;
		if(IsOperator(s[i])&&s[i]!='!')
			i++;
		else
			return false;
		while(s[i]=='!')i++;
		if(Isalpha(s[i]))
			i++;
		else
			return false;
		if(i==end+1)
			return true;
		else
			return false;
	}
	else{
		bool f1=true,f2=true;
		int substart,i=start;
		while(s[i]=='!')i++;
		if(s[i]=='('){
			i++;substart=i;count=1;
			while(count!=0){ if(s[i]=='(')count++;else if(s[i]==')')count--;i++;}
			f1=IsLegal(s,substart,i-2);
		}
		else if(Isalpha(s[i]))
			i++;
		else
			return false;
		if(i==end+1)return f1;
		if(IsOperator(s[i])&&s[i]!='!')
			i++;
		else
			return false;
		while(s[i]=='!')i++;
		if(s[i]=='('){
			i++;substart=i;count=1;
			while(count!=0){ if(s[i]=='(')count++;else if(s[i]==')')count--;i++;}
			f2=IsLegal(s,substart,i-2);
		}
		else if(Isalpha(s[i]))
			i++;
		else
			return false;
		if(i!=end+1)
			return false;
		if(f1&&f2)
			return true;
		else
			return false;
	}
}

int C推理機View::SimplifyCnf(char *s){
	int i=0,j=0,len=strlen(s);
	while(i<len){
		myset temp;
		while(s[i]!='*'&&s[i]!='\0'){
			if(s[i]=='!'){
				i++;
				atomic at;
				at.flag=1;at.c=s[i];
				temp.push(at);
			}
			else if(Isalpha(s[i])){
				atomic at;
				at.flag=0;at.c=s[i];
			temp.push(at);
			}
			i++; 
		}
		int t=temp.cnf();
		if(!temp.IsEmpty()&&t!=1){
			temp.SetFirst();
			if(!temp.Isat())s[j++]='(';
			while(!temp.IsEnd()){
			if(temp.GetData().flag==1){
				s[j++]='!';
				s[j++]=temp.GetData().c;
				s[j++]='+';}
			else if(temp.GetData().flag==0){
			s[j++]=temp.GetData().c;
			s[j++]='+';
			}
			temp.Next();}
			j--;
			if(!temp.Isat())s[j++]=')';
			s[j++]='*';
		}
		i++;	
		temp.MakeEmpty();
	}
	if(j!=0)s[j-1]='\0';
	else s[0]='\0';
	i=0; myset set;
	if(strlen(s)==0)
		return 1;
	int p[58]={0};
	while(i<(int)strlen(s)){
		if(i==0||s[i]=='*'){
			if(i!=0)i++;
			if(s[i]=='('){ while(s[i]!=')') i++;continue;}
			if(s[i]=='!'){
				i++;
				if(p[int(s[i]-'A')]==0)p[int(s[i]-'A')]=1;
				else if(p[int(s[i]-'A')]==2)
					return -1;
				else{
					for(int k=i+1;k<=(int)strlen(s);k++)
						s[k-3]=s[k];
					i=i-3;
				}
			}
			else if(Isalpha(s[i])){
				if(p[int(s[i]-'A')]==0)p[int(s[i]-'A')]=2;
				else if(p[int(s[i]-'A')]==1)
					return -1;
				else{
					for(int k=i+1;k<=(int)strlen(s);k++)
						s[k-2]=s[k];
					i=i-2;
				}
			}
		}
		i++;
	}
	return 0;
}

int C推理機View::SimplifyDnf(char *s){
	int i=0,j=0,len=strlen(s);
	while(i<len){
		myset temp;
		while(s[i]!='+'&&s[i]!='\0'){
			if(s[i]=='!'){
				i++;
				atomic at;
				at.flag=1;at.c=s[i];
				temp.push(at);
			}
			else if(Isalpha(s[i])){
				atomic at;
				at.flag=0;at.c=s[i];
			temp.push(at);
			}
			i++; 
		}
		if(temp.dnf()){
			temp.SetFirst();
			if(!temp.Isat())s[j++]='(';
			while(!temp.IsEnd()){
			if(temp.GetData().flag==1){
				s[j++]='!';
				s[j++]=temp.GetData().c;
				s[j++]='*';}
			else if(temp.GetData().flag==0){
			s[j++]=temp.GetData().c;
			s[j++]='*';
			}
			temp.Next();}
			j--;
			if(!temp.Isat())s[j++]=')';
			s[j++]='+';
		}
		i++;	
		temp.MakeEmpty();
	}
	if(j!=0)s[j-1]='\0';
	else s[0]='\0';
	i=0; myset set;
	if(strlen(s)==0)
		return -1;
	int p[58]={0};
	while(i<(int)strlen(s)){
		if(i==0||s[i]=='+'){
			if(i!=0)i++;
			if(s[i]=='('){ while(s[i]!=')') i++;continue;}
			if(s[i]=='!'){
				i++;
				if(p[int(s[i]-'A')]==0)p[int(s[i]-'A')]=1;
				else if(p[int(s[i]-'A')]==2)
					return 1;
				else{
					for(int k=i+1;k<=(int)strlen(s);k++)
						s[k-3]=s[k];
					i=i-3;
				}
			}
			else if(Isalpha(s[i])){
				if(p[int(s[i]-'A')]==0)p[int(s[i]-'A')]=2;
				else if(p[int(s[i]-'A')]==1)
					return 1;
				else{
					for(int k=i+1;k<=(int)strlen(s);k++)
						s[k-2]=s[k];
					i=i-2;
				}
			}
		}
		i++;
	}
	return 0;
}
void C推理機View::On32777()
{
	// TODO: Add your command handler code here
	help he;
	he.DoModal();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲二区在线观看| 一本大道av一区二区在线播放| 国内精品写真在线观看| 风间由美中文字幕在线看视频国产欧美 | 国产综合色产在线精品| 国产一区二区三区| 在线免费观看不卡av| 欧美精品tushy高清| 26uuu国产日韩综合| 一区二区三区日韩欧美| 欧美aa在线视频| 99久久国产免费看| 日韩一区二区在线播放| 国产精品乱人伦中文| 美日韩一级片在线观看| 97精品久久久久中文字幕| 欧美va亚洲va在线观看蝴蝶网| 国产精品久久久久国产精品日日| 亚洲成人动漫精品| 成人动漫视频在线| 日韩一区二区三区视频| 成人免费在线视频观看| 国产在线视频不卡二| 欧美在线不卡视频| 久久久欧美精品sm网站| 青青草97国产精品免费观看无弹窗版| 99热99精品| 精品少妇一区二区三区| 亚洲国产欧美在线| k8久久久一区二区三区| 久久中文娱乐网| 日韩电影一区二区三区| 日本丶国产丶欧美色综合| 国产亚洲精品aa午夜观看| 日韩国产一二三区| 欧美日韩一本到| 亚洲综合成人网| 一本一道波多野结衣一区二区| 精品粉嫩aⅴ一区二区三区四区| 午夜精品福利一区二区三区av| 成人网男人的天堂| 欧美撒尿777hd撒尿| 一区二区三区在线免费播放| 久久黄色级2电影| 日韩精品一区在线| 狠狠v欧美v日韩v亚洲ⅴ| 欧美一区二区美女| 午夜精品久久久久久不卡8050| 99在线精品一区二区三区| 久久精品一区四区| 国产福利一区二区三区视频| 久久精品欧美一区二区三区麻豆| 久久99热这里只有精品| 国产精品毛片a∨一区二区三区| 91免费观看国产| 日日欢夜夜爽一区| 久久久99久久精品欧美| 色婷婷综合久久久久中文 | 麻豆精品在线看| 久久精品亚洲一区二区三区浴池 | 欧美国产日韩a欧美在线观看| 国产99久久久精品| 亚洲第四色夜色| 国产午夜精品美女毛片视频| 色久综合一二码| 九九国产精品视频| 一区在线观看视频| 日韩欧美一区二区不卡| 成人精品一区二区三区四区| 午夜精品久久久久| 国产精品久久三区| 日韩一卡二卡三卡四卡| 91小视频在线观看| 人妖欧美一区二区| 亚洲婷婷综合色高清在线| 欧美一区二区免费| 色婷婷激情久久| 国产精品一卡二| 亚洲国产另类av| 欧美国产精品中文字幕| 欧美疯狂做受xxxx富婆| 9色porny自拍视频一区二区| 久久精品国产一区二区| 亚洲人成电影网站色mp4| 日韩欧美一区中文| 欧美亚洲一区二区在线观看| 风间由美一区二区三区在线观看| 日韩和欧美一区二区三区| 亚洲精品乱码久久久久久| 久久综合色之久久综合| 3751色影院一区二区三区| 99精品视频一区| 国产成人综合网站| 老司机免费视频一区二区三区| 一二三四社区欧美黄| 国产精品系列在线| 久久久久88色偷偷免费| 日韩精品一区二区三区中文精品| 欧美日韩在线播放一区| 一本久久综合亚洲鲁鲁五月天| 国产精品18久久久久久久网站| 免费一级欧美片在线观看| 午夜精品aaa| 亚洲国产欧美在线人成| 亚洲国产裸拍裸体视频在线观看乱了 | 成人精品电影在线观看| 国产精品99久久久久| 国内精品伊人久久久久av一坑| 欧美a一区二区| 免费久久99精品国产| 日本视频中文字幕一区二区三区| 亚洲成人自拍一区| 天天综合天天做天天综合| 亚洲成av人片在线观看| 婷婷综合五月天| 日韩av中文字幕一区二区三区| 香港成人在线视频| 免费的国产精品| 精品一区二区三区在线播放视频| 三级欧美韩日大片在线看| 首页亚洲欧美制服丝腿| 免费成人你懂的| 韩国av一区二区三区四区 | 久久国产夜色精品鲁鲁99| 乱一区二区av| 国产麻豆精品在线| 风间由美中文字幕在线看视频国产欧美| 懂色av一区二区夜夜嗨| 97国产一区二区| 欧美日韩视频在线观看一区二区三区 | 欧美午夜精品理论片a级按摩| 欧美三日本三级三级在线播放| 3atv一区二区三区| 久久久国产一区二区三区四区小说| 国产日韩综合av| 一区二区视频在线| 奇米777欧美一区二区| 国产成人夜色高潮福利影视| 99视频精品免费视频| 欧美三级在线播放| 久久综合丝袜日本网| 亚洲欧美综合网| 亚洲精品大片www| 精品一区二区三区日韩| 福利电影一区二区三区| 色综合色狠狠综合色| 欧美一区二区三区爱爱| 国产精品久久久久久久久快鸭 | 亚洲男人的天堂在线观看| 亚洲国产精品久久久久婷婷884| 久久精品国产成人一区二区三区 | 国产精品久久久久国产精品日日| 亚洲一区电影777| 国产成人一级电影| 欧美日韩色一区| 亚洲国产精品国自产拍av| 午夜国产精品影院在线观看| 国产99久久久久久免费看农村| 欧美日韩综合色| 欧美激情中文不卡| 奇米色一区二区| 欧美性猛交xxxxxxxx| 国产午夜精品福利| 日韩av中文在线观看| 色网综合在线观看| 久久老女人爱爱| 日韩**一区毛片| 欧美优质美女网站| 亚洲国产精品99久久久久久久久| 日韩vs国产vs欧美| 在线精品视频免费播放| 国产精品久久福利| 国产一区久久久| 91精品久久久久久久91蜜桃| 亚洲免费大片在线观看| 春色校园综合激情亚洲| 欧美草草影院在线视频| 亚洲丰满少妇videoshd| 色国产综合视频| 亚洲欧洲日产国码二区| 国产成人午夜精品影院观看视频 | 亚洲精品在线电影| 日韩福利电影在线观看| 欧美日韩国产片| 夜夜亚洲天天久久| 91亚洲精华国产精华精华液| 中文字幕av免费专区久久| 狠狠色丁香婷综合久久| 日韩亚洲欧美在线观看| 午夜精品福利一区二区蜜股av | 色琪琪一区二区三区亚洲区| 国产欧美精品一区二区三区四区| 精品午夜一区二区三区在线观看| 欧美一区二区三区啪啪| 全部av―极品视觉盛宴亚洲| 欧美一区二区视频网站| 免费观看在线综合| 精品久久久久久综合日本欧美| 久久国产三级精品| 久久视频一区二区|