当前位置: 首页>>代码示例>>C++>>正文


C++ TList::GetData方法代码示例

本文整理汇总了C++中TList::GetData方法的典型用法代码示例。如果您正苦于以下问题:C++ TList::GetData方法的具体用法?C++ TList::GetData怎么用?C++ TList::GetData使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在TList的用法示例。


在下文中一共展示了TList::GetData方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: Repeat

int TAstar::Repeat(TList<TAstar> &L)  
{  
    int n=L.Getlen(); 
	int i; 
    for( i=0;i<n;i++)  
        if(L.GetData(i)==*this)  
            break;  
    return i;  
}  
开发者ID:XiaohengLiu,项目名称:8-puzzle,代码行数:9,代码来源:tastar.cpp

示例2: Search

void TAstar::Search()
{
	TAstar T = *this;              //初始结点   
	T.f = T.Calcuf();               //初始结点的估价函数   
	TList<TAstar> L;           //建立队列   
	L.Append(T);                 //初始结点入队   
	int head = 0, tail = 0;           //队列头和尾指针   
	while (head <= tail)           //队列不空则循环   
	{
		for (int i = 0; i<4; i++)            //空格可能移动方向   
		{
			T = L.GetData(head);   //去队列头结点   
			if (T.h == 0)                   //是目标结点   
			{
				T.Printl(L);//输出搜索路径   
				//T.Printf();    //输出目标状态   
				//printf("%d\n", T.getZeroPos());
				this->rs.push_back(T.getZeroPos());
				return;        //结束   
			}
			if (T.Expend(i))          //若结点可扩展   
			{
				int k = T.Repeat(L); //返回与已扩展结点重复的序号        
				if (k<head)               //如果是不能扩展的结点   
					continue; //丢弃   
				T.last = head;      //不是不能扩展的结点,记录父结点   
				T.f = T.Calcuf(); //计算f   
				if (k <= tail)         //新结点与可扩展结点重复   
				{
					TAstar Temp = L.GetData(k);
					if (Temp.g>T.g)         //比较两结点g值   
						L.SetData(T, k); //保留g值小的   
					continue;
				}
				T.Sort(L, head);            //新结点插入可扩展结点队列        
				tail++;        //队列尾指针后移    
			}
		}
		head++; //一个结点不能再扩展,队列头指针指向下一结点   
	}
}
开发者ID:doctording,项目名称:cocos2dx_8digital,代码行数:41,代码来源:TAstar.cpp

示例3: Sort

void TAstar::Sort(TList<TAstar>& L,int k)  
{  
    int n=L.Getlen();
	int i;  
    for( i=k+1;i<n;i++)  
    {  
        TAstar T=L.GetData(i);  
        if(this->f<=T.f)  
            break;  
    }  
    L.Insert(*this,i);  
}  
开发者ID:XiaohengLiu,项目名称:8-puzzle,代码行数:12,代码来源:tastar.cpp

示例4: Printl

void TAstar::Printl(TList<TAstar> L)   
{  
    TAstar T=*this;  
    if(T.last==-1)  
        return;  
    else  
    {  
        T=L.GetData(T.last);  
        T.Printl(L);  
        T.Printf();  
    }  
}  
开发者ID:XiaohengLiu,项目名称:8-puzzle,代码行数:12,代码来源:tastar.cpp

示例5: Printl

void TAstar::Printl(TList<TAstar> L)
{
	TAstar T = *this;
	if (T.last == -1)
		return;
	else
	{
		T = L.GetData(T.last);
		T.Printl(L);
		//T.Printf();
		//printf("%d\n", T.getZeroPos());
		this->rs.push_back(T.getZeroPos());
	}
}
开发者ID:doctording,项目名称:cocos2dx_8digital,代码行数:14,代码来源:TAstar.cpp


注:本文中的TList::GetData方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。