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

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

?? cykdetectingdlg.cpp

?? VC實現CYK語法判斷檢測,CYK是經典的人工智能判斷法之一
?? CPP
字號:
// CYKDetectingDlg.cpp : implementation file
//

#include "stdafx.h"
#include "CYKDetecting.h"
#include "CYKDetectingDlg.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CCYKDetectingDlg dialog

CCYKDetectingDlg::CCYKDetectingDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CCYKDetectingDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CCYKDetectingDlg)
	m_sVn = _T("");
	m_sResult = _T("");
	m_sRuleDisplay = _T("");
	m_sSingleRule = _T("");
	m_sStringForDetecting = _T("");
	m_sVt = _T("");
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CCYKDetectingDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CCYKDetectingDlg)
	DDX_Text(pDX, IDC_NOTTERMINATE, m_sVn);
	DDX_Text(pDX, IDC_RESULT, m_sResult);
	DDX_Text(pDX, IDC_RULEDISPLAY, m_sRuleDisplay);
	DDX_Text(pDX, IDC_SINGLERULE, m_sSingleRule);
	DDX_Text(pDX, IDC_STRINGFORDETECTING, m_sStringForDetecting);
	DDX_Text(pDX, IDC_TERMINATE, m_sVt);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CCYKDetectingDlg, CDialog)
	//{{AFX_MSG_MAP(CCYKDetectingDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_ADD, OnAdd)
	ON_BN_CLICKED(IDC_DELETERULE, OnDeleterule)
	ON_BN_CLICKED(IDC_IDENTIFY, OnIdentify)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CCYKDetectingDlg message handlers

BOOL CCYKDetectingDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	m_nStringNum=0;
	m_sRuleList.RemoveAll();
	m_sRule1.RemoveAll();
	m_sRule2.RemoveAll();
	m_sDetectingMatrix.RemoveAll();
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CCYKDetectingDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CCYKDetectingDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CCYKDetectingDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CCYKDetectingDlg::OnAdd() 
{
	// TODO: Add your control notification handler code here
	UpdateData(TRUE);
	if(!m_sSingleRule.IsEmpty())
	{
		m_sRuleList.AddTail(m_sSingleRule);
		//加入此文法規則,每個規則之間用空格隔開顯示
        m_sRuleDisplay=m_sRuleDisplay+m_sSingleRule+" ";
		m_sSingleRule="";
		UpdateData(FALSE);
	}
}

void CCYKDetectingDlg::OnDeleterule() 
{
	// TODO: Add your control notification handler code here
	UpdateData(TRUE);
	if(!m_sRuleDisplay.IsEmpty())
	{
		CString s=m_sRuleList.RemoveTail();
		//刪除最近加入的一個文法規則以及空格
        m_sRuleDisplay=m_sRuleDisplay.Left(m_sRuleDisplay.GetLength()-s.GetLength()-1);
		UpdateData(FALSE);
	}
}

void CCYKDetectingDlg::OnIdentify() 
{
	// TODO: Add your control notification handler code here
	UpdateData(TRUE);
	if (m_sVn.IsEmpty())
	{
		AfxMessageBox("非終止符集不能為空!",MB_OK);
		return;
	}
	if (m_sVt.IsEmpty())
	{
		AfxMessageBox("終止符集不能為空!",MB_OK);
		return;
	}
	if (m_sStringForDetecting.IsEmpty())
	{
		AfxMessageBox("待檢測字符串不能為空!",MB_OK);
		return;
	}
	int i,j,d,e,f,p,q,r,s,t,m=0,n=0;
	//對文法規則進行分類
	POSITION pos=m_sRuleList.GetHeadPosition();
	while (pos!=NULL)
	{
		CString ss=m_sRuleList.GetNext(pos);
		if(ss.GetLength()==3)
		{
			//m_sRule1為第一類A->BC,長度3
			m_sRule1.Add(ss);
			m++;
		}
		else
		{
			//m_sRule2為第二類A->a,長度2
			m_sRule2.Add(ss);
			n++;
		}
	}
	m_nStringNum=m_sStringForDetecting.GetLength();//待檢測字符串長度
	//構造識別矩陣
	m_sDetectingMatrix.SetSize((m_nStringNum+1)*(m_nStringNum+1));
	m_sDetectingMatrix[0]="0";
	for(i=0;i<m_nStringNum+1;i++)
		for(j=0;j<i;j++)
			m_sDetectingMatrix[i*(m_nStringNum+1)+j]="0";
	for(i=0;i<m_nStringNum+1;i++)
		m_sDetectingMatrix[i*(m_nStringNum+1)+i]=m_sStringForDetecting.Mid(i-1,1);
    for(i=0;i<m_nStringNum+1;i++)
		for(j=i+1;j<m_nStringNum+1;j++)
			m_sDetectingMatrix[i*(m_nStringNum+1)+j]=NULL;
	for(i=1;i<m_nStringNum+1;i++)
		for(j=0;j<n;j++)
			if(m_sRule2[j].GetAt(1)==m_sDetectingMatrix[i*(m_nStringNum+1)+i])
				m_sDetectingMatrix[(i-1)*(m_nStringNum+1)+i]+=m_sRule2[j].GetAt(0);
	for(d=2;d<m_nStringNum+1;d++)
		for(e=d;e<m_nStringNum+1;e++)
		{
			i=e-d;
			j=e;
			for(f=i+1;f<j;f++)
				if(p=m_sDetectingMatrix[i*(m_nStringNum+1)+f].GetLength())
					for(r=0;r<p;r++)
						for(s=0;s<m;s++)
							if(m_sRule1[s].GetAt(1)==m_sDetectingMatrix[i*(m_nStringNum+1)+f].GetAt(r))
								if(q=m_sDetectingMatrix[f*(m_nStringNum+1)+j].GetLength())
									for(t=0;t<q;t++)
										if(m_sRule1[s].GetAt(2)==m_sDetectingMatrix[f*(m_nStringNum+1)+j].GetAt(t))
											m_sDetectingMatrix[i*(m_nStringNum+1)+j]+=m_sRule1[s].GetAt(0);
		}
	if(m_sDetectingMatrix[m_nStringNum].Find('S')==-1)
		m_sResult="The string can't be recognized!";
	else
        m_sResult="The string can be recognized!";
	UpdateData(FALSE);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91丨国产丨九色丨pron| 午夜视频一区二区| 日韩精品资源二区在线| 91在线国产福利| 99视频有精品| www.av精品| 一本到不卡精品视频在线观看| 蜜桃一区二区三区在线| 视频精品一区二区| 亚洲高清三级视频| 天涯成人国产亚洲精品一区av| 一区二区三区av电影| 一区二区三区免费网站| 亚洲一区二区三区中文字幕在线| 亚洲综合免费观看高清完整版 | 韩国成人在线视频| 日本不卡中文字幕| 韩国av一区二区| 国产不卡在线一区| 91丨porny丨首页| 欧美一卡2卡三卡4卡5免费| 日韩精品一区二区三区蜜臀| 久久婷婷综合激情| 国产精品网站一区| 三级在线观看一区二区| 国产成人三级在线观看| 色综合中文综合网| 一区二区三区精密机械公司| 亚洲欧美日韩一区| 免费精品视频在线| 91麻豆国产福利在线观看| 欧美体内she精视频| 久久久精品tv| 天天色天天爱天天射综合| 国模大尺度一区二区三区| av高清不卡在线| 日韩欧美精品在线视频| 亚洲免费在线看| 国产高清久久久| 2019国产精品| 日本欧美加勒比视频| 91小宝寻花一区二区三区| 欧美日韩国产bt| 综合欧美亚洲日本| 国产99久久久久久免费看农村| 91黄色免费看| 久久蜜臀中文字幕| 蜜臀av性久久久久蜜臀aⅴ四虎| 色狠狠色噜噜噜综合网| 日本一区二区电影| 国产一区视频网站| www成人在线观看| 亚洲乱码国产乱码精品精的特点| 极品美女销魂一区二区三区| 91精品国产全国免费观看| 污片在线观看一区二区| 欧美日韩亚洲另类| 日本va欧美va精品发布| 欧美一卡2卡三卡4卡5免费| 日韩高清电影一区| 色噜噜久久综合| 一区二区久久久久| 99久久久久久99| 亚洲美女在线国产| 欧美一区二区性放荡片| 日韩精品免费专区| 久久综合久久99| 国产高清精品久久久久| 在线成人av影院| 国产a级毛片一区| 亚洲日本丝袜连裤袜办公室| 91搞黄在线观看| 国产精品中文字幕一区二区三区| 中文av字幕一区| 在线视频你懂得一区| 一区二区三区不卡视频在线观看| 欧美日韩综合不卡| 裸体一区二区三区| 亚洲品质自拍视频网站| 日韩欧美综合在线| 一本色道久久综合亚洲aⅴ蜜桃| 肉色丝袜一区二区| 亚洲人成在线观看一区二区| 欧美一级专区免费大片| 国产在线一区观看| 奇米影视在线99精品| 亚洲美女视频在线观看| 中文子幕无线码一区tr| 91精品国产乱| 国产成人综合视频| 精品一二线国产| 亚洲一区二区三区四区五区中文| 91精品国产91久久综合桃花| 九色|91porny| 久久久久久久久97黄色工厂| 亚洲欧美偷拍卡通变态| 欧美电影精品一区二区| 日韩欧美色电影| 欧美少妇xxx| 欧美在线免费观看视频| 91在线无精精品入口| 国内欧美视频一区二区| 国产一区二区三区四| 国产精品一区二区男女羞羞无遮挡| 日韩电影一二三区| 精品制服美女久久| 国产成人精品亚洲777人妖| 国产精品一区二区黑丝| 成人性生交大片免费看中文| 国产亚洲福利社区一区| 中文字幕亚洲区| 国产精品热久久久久夜色精品三区 | 91久久免费观看| 色天使色偷偷av一区二区| 欧美日韩一区二区三区高清| 69成人精品免费视频| 久久亚洲精品国产精品紫薇| 欧美国产激情一区二区三区蜜月| 国产精品你懂的在线| 亚洲一区成人在线| 国产精品一级片在线观看| 成人av资源站| 久久久久国色av免费看影院| 亚洲激情自拍偷拍| 亚洲男人天堂av网| 毛片av一区二区三区| 91在线免费视频观看| 欧美一级久久久久久久大片| 国产精品午夜春色av| 亚洲午夜久久久久久久久电影院| 久久成人av少妇免费| 欧美喷潮久久久xxxxx| 亚洲欧洲色图综合| 国产精品白丝jk黑袜喷水| 欧美视频一区二| 国产精品色噜噜| 成人免费视频国产在线观看| 日韩女优制服丝袜电影| 亚洲高清视频的网址| 欧美午夜电影一区| 一级做a爱片久久| 成人国产精品视频| 国产欧美一区二区精品性| 国产一区二区毛片| 日本一区二区三级电影在线观看| 久久福利视频一区二区| 精品粉嫩aⅴ一区二区三区四区| 日韩av电影免费观看高清完整版在线观看 | 一本色道a无线码一区v| 1000部国产精品成人观看| 在线免费精品视频| 欧美96一区二区免费视频| 欧美日韩亚洲丝袜制服| 久久99精品久久久久| 久久综合九色综合97婷婷女人 | 久久亚洲精品国产精品紫薇| 国产九色sp调教91| 中文字幕亚洲区| 欧美老肥妇做.爰bbww视频| 久久精品国产77777蜜臀| 日韩午夜电影在线观看| 天堂蜜桃91精品| 欧美日韩一区二区在线观看视频| 日韩成人免费看| 国产日韩欧美激情| 欧美日韩成人激情| 懂色av一区二区夜夜嗨| 中文乱码免费一区二区| 成人午夜电影小说| 亚洲狠狠爱一区二区三区| 国产激情偷乱视频一区二区三区| 日韩美女一区二区三区| 国产在线精品免费| 亚洲乱码国产乱码精品精的特点 | 麻豆一区二区99久久久久| 一区二区三区在线免费观看| 日韩欧美黄色影院| 免费看欧美美女黄的网站| 国产日韩欧美高清在线| 日韩精品一区二| 日韩一区二区三区三四区视频在线观看| 成人国产电影网| 国产suv精品一区二区6| 蜜臀久久久99精品久久久久久| 亚洲精品国产无天堂网2021| 国产精品伦理一区二区| 国产女主播视频一区二区| 欧美日本在线看| 91精品国产91综合久久蜜臀| 在线播放一区二区三区| 欧美一区二区视频在线观看2022 | 欧美色精品在线视频| 欧美亚洲精品一区| 欧美日韩一区高清| 91精品国产一区二区人妖| 精品久久久久久亚洲综合网 | 久久久久久免费网| 欧美一级欧美一级在线播放| 亚洲欧美在线aaa| 久久国产成人午夜av影院|