禁忌搜索算法源代码

Python012

禁忌搜索算法源代码,第1张

禁忌搜索法:使用一个禁忌表,记录下不允许搜索的元素。在后面的搜索中,根据禁忌表来决定如何处理当前元素。用在约瑟夫环中,我们可以用一个数组记录下已经出圈的人的编号,这样再数数时,可以根据禁忌表来判断此人是否还在圈内。

#define N 100

void yuesefu1(int data[],int result[],int sum,int k)

{

int i=0,j=0,count=0

int n

while(count<sum)

{

for(n=0n<countn++)/*根据禁忌表判断此人是否还在圈内*/

if(result[n]==data[i])

break

if(n>=count)/*若此人还在圈内*/

j++

if(j==k)

{

result[count++]=data[i]/*把出圈的人的编号存入禁忌表*/

j=0

}

i++

if(i==sum)

i=0

}

}

void main()

{

int data[N]

int result[N]={0}

int i,j,total,k

printf("\nPlease input the number of every people.\n")

for(i=0i<N)

{

int input

scanf("%d",&input)

if(input==0)

break

for(j=0j<ij++)

if(data[j]==input)

break

if(j>=i&&input>0)

{

data[i]=input

i++

}

else

printf("\nData error.Re-input:")

}

total=i

printf("\nYou have input:\n")

for(i=0i<totali++)

{

if(i%10==0)

printf("\n")

printf("%4d",data[i])

}

printf("\nPlease input a number to count:")

scanf("%d",&k)

yuesefu1(data,result,total,k)

printf("\nThe sequence is:\n")

for(i=0i<totali++)

printf("%d ",result[i])

1、在搜索中,构造一个短期循环记忆表-禁忌表,禁忌表中存放刚刚进行过的 |T|(T称为禁忌表)个邻居的移动,这种移动即解的简单变化。

2、禁忌表中的移动称为禁忌移动。对于进入禁忌表中的移动, 在以后的 |T| 次循环内是禁止的,以避免回到原来的解,从而避免陷入循环。|T| 次循环后禁忌解除。

3、禁忌表是一个循环表,在搜索过程中被循环的修改,使禁忌表始终保持 |T| 个移动。

4、即使引入了禁忌表,禁忌搜索仍可能出现循环。因此,必须给定停止准则以避免出现循环。当迭代内所发现的最好解无法改进或无法离开它时,算法停止。

姓名:刘家沐

学号:19011210553

网络来源,有删减

【嵌牛导读】:针对TSP问题等类似的NP-hard 问题,如果能在尽量少的计算量的情况下找到一个最优或者是较优的解成为当前一个热门的讨论话题,禁忌搜索算法便是其中之一

【嵌牛鼻子】:禁忌搜索算法   最优化问题    TSP问题

【嵌牛正文】:

背景:禁忌搜索算法(Tabu Search)是由美国科罗拉多州大学的Fred Glover教授在1986年左右提出来的,是一个用来跳出局部最优的搜寻方法。在解决最优问题上,一般区分为两种方式:一种是传统的方法,另一种方法则是一些启发式搜索算法。

使用传统的方法,我们必须对每一个问题都去设计一套算法,相当不方便,缺乏广泛性,优点在于我们可以证明算法的正确性,我们可以保证找到的答案是最优的;而对于启发式算法,针对不同的问题,我们可以套用同一个架构来寻找答案,在这个过程中,我们只需要设计评价函数以及如何找到下一个可能解的函数等,所以启发式算法的广泛性比较高,但相对在准确度上就不一定能够达到最优,但是在实际问题中启发式算法那有着更广泛的应用。 

禁忌搜索是一种亚启发式随机搜索算法,它从一个初始可行解出发,选择一系列的特定搜索方向(移动)作为试探,选择实现让特定的目标函数值变化最多的移动。为了避免陷入局部最优解,TS搜索中采用了一种灵活的“记忆”技术,对已经进行的优化过程进行记录和选择,指导下一步的搜索方向。 TS是人工智能的一种体现,是局部领域搜索的一种扩展。禁忌搜索是在领域搜索的基础上,通过设置禁忌表来禁忌一些已经历的操作,并利用藐视准则来奖励一些优良状态,其中涉及邻域 、禁忌表、禁忌长度、候选解、藐视准则等影响禁忌搜索算法性能的关键因素。迄今为止,TS算法在组合优化等计算机领域取得了很大的成功,近年来又在函数全局优化方面得到较多的研究,并大有发展的趋势。

局域搜索:在一个小的搜索范围里,进行搜索,或者根据结果逐步扩大搜索范围,但是这样会容易陷入局部最优

为了获得好解,可以采用的策略有(1)扩大邻域结构,(2)变邻域结构    ,(3)多初始点。但这些策略依然无法保证算法具备跳出局优的能力。

禁忌搜索:

为了找到“全局最优解”,就不应该执着于某一个特定的区域。局部搜索的缺点就是太贪婪地对某一个局部区域以及其邻域搜索,导致一叶障目,不见泰山。 禁忌搜索 就是对于找到的一部分局部最优解,有意识地避开它(但不是完全隔绝),从而获得更多的搜索区间。兔子们找到了泰山,它们之中的一只就会留守在这里,其他的再去别的地方寻找。就这样,一大圈后,把找到的几个山峰一比较, 珠穆朗玛峰 脱颖而出。

当兔子们再寻找的时候,一般地会有意识地避开泰山,因为他们知道,这里已经找过,并且有一只兔子在那里看着了。这就是禁忌搜索中“禁忌表(tabu list)”的含义。那只留在泰山的兔子一般不会就安家在那里了,它会在一定时间后重新回到找最高峰的大军,因为这个时候已经有了许多新的消息,泰山毕竟也有一个不错的高度,需要重新考虑,这个归队时间,在禁忌搜索里面叫做“禁忌长度(tabu length)”;如果在搜索的过程中,留守泰山的兔子还没有归队,但是找到的地方全是华北平原等比较低的地方,兔子们就不得不再次考虑选中泰山,也就是说,当一个有兔子留守的地方优越性太突出,超过了“best so far”的状态,就可以不顾及有没有兔子留守,都把这个地方考虑进来,这就叫“特赦准则(aspiration criterion)”。这三个概念是禁忌搜索和一般搜索准则最不同的地方,算法的优化也关键在这里。

主要思路:

1、在搜索中,构造一个短期循环记忆表-禁忌表,禁忌表中存放刚刚进行过的 |T|(T称为禁忌表)个邻居的移动,这种移动即解的简单变化。

2、禁忌表中的移动称为禁忌移动。对于进入禁忌表中的移动, 在以后的 |T| 次循环内是禁止的,以避免回到原来的解,从而避免陷入循环。|T| 次循环后禁忌解除。

3、禁忌表是一个循环表,在搜索过程中被循环的修改,使禁忌表始终保持 |T| 个移动。

4、即使引入了禁忌表,禁忌搜索仍可能出现循环。因此,必须给定停止准则以避免出现循环。当迭代内所发现的最好解无法改进或无法离开它时,算法停止。

总结:

与传统的优化算法相比,TS算法的主要特点是:

 1.从移动规则看,每次只与最优点比较,而不与经过点比较,故可以爬出局部最优。

 2.选优规则始终保持曾经达到的最优点,所以即使离开了全局最优点也不会失去全局最优性。

 3.终止规则不以达到局部最优为终止规则,而以最大迭代次数、出现频率限制或者目标值偏离成都为终止规则

禁忌搜索是对人类思维过程本身的一种模拟,它通过对一些局部最优解的禁忌(也可以说是记忆)达到接纳一部分较差解,从而跳出局部搜索的目的。因而在计算搜索领域有着广泛应用。