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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? problem.cpp

?? 隨機(jī)vrp 3
?? CPP
字號(hào):
#include "Problem.h"

#include <cmath>

Problem::Problem( Control& control) {
  //   This function has the following (side) effects:
  //   1.reads in a problem instance from file,
  //   2.computes the cost matrix, if coordinates are given in problem instance,
  //   3.computes demands and probability distribution of demands
  //   for each customer
  //   4.if the capacity is given from command line, the vehicle capacity is
  //   assigned this value, instead of the value read from the input file (after verification
  //   that the new value is not smaller than the biggest possible customer demand).
  //   Note: probability distribution of customer i is uniform on the interval
  //   [avgDmnd[i]-spread[i], avgDmnd[i]+spread[i]].

    istream& ifs = control.getInputStream();
    ifs >> numberOfCustomers;
    
    vector<int> avgDmnd(numberOfCustomers);
    vector<int> spread(numberOfCustomers);

    vector<vector<double> > xyCustomers(numberOfCustomers); 

    //Allocation of distance matrix.
    distanceMatrix = vector<vector<double> >(numberOfCustomers);
    for(int i=0;i<numberOfCustomers; i++)
        distanceMatrix[i] = vector<double>(numberOfCustomers);
  
  if(control.getFlagMatrix() == false){
      //Temporary quantities to be read from ifs.
      for(int i=0; i<numberOfCustomers; i++)
          xyCustomers[i] = vector<double>(2);

        
      //Read data from ifs.
      int i=0;
      while(i<numberOfCustomers){
          ifs >> i;
          ifs >> xyCustomers[i][0] >> xyCustomers[i][1];
          ifs >> avgDmnd[i] >> spread[i];
          i++;
      }


      //Compute distance matrix.
      for(int i=0;i<numberOfCustomers; i++){
          for(int j=0; j<numberOfCustomers; j++){
              distanceMatrix[i][j]= sqrt((xyCustomers[i][0]-xyCustomers[j][0])
                                         *(xyCustomers[i][0]-xyCustomers[j][0]) +
                                         (xyCustomers[i][1]-xyCustomers[j][1])
                                         *(xyCustomers[i][1]-xyCustomers[j][1]));
          }  
  
      }
  }
  else if(control.getFlagMatrix() == true){
      //Read demand and spread data from ifs.
      int i=0;
      while(i<numberOfCustomers){
          ifs >> i;
          ifs >> avgDmnd[i] >> spread[i];
          //cout << avgDmnd[i] << " "  << spread[i] << " " << endl;/////
          i++;
      }
      //Read distance matrix from ifs.
      i=0;
      int j=0;
      while(i<numberOfCustomers){
          while(j<numberOfCustomers){
              ifs >> distanceMatrix[i][j];
              //cout << distanceMatrix[i][j] << " ";//////
              j++;
          }
          //cout << endl;///
          j=0;
          i++;
      }
  }
  else {
      cerr << "Problem.cpp Error:  control.getMatrix is neither true nor false, exiting" << endl;
      exit(-1);
  }

  //Compute customers demands and  probabilities (uniform on an interval).
  customerDemand = vector<vector<PossibleDemand> >(numberOfCustomers);
  int maxDmnd=0;     //maximum possible demand
  double averageDmnd=0.0; //average demand over all customers
  
  for(int i=0; i<numberOfCustomers; i++){ 
    //Dealing with boundary condition
   if ((avgDmnd[i] - spread[i])<0) {
      avgDmnd[i] = spread[i];
    }
    customerDemand[i] = vector<PossibleDemand>(2*spread[i]+1);
    averageDmnd+= avgDmnd[i];
    for(int d=0; d< (2*spread[i] +1); d++){
      int demand = avgDmnd[i]-(spread[i] - d);
      //Dealing with boundary condition.
      //if ( demand > 0 ) 
	customerDemand[i][d].demand_ = demand;
	//else customerDemand[i][d].demand_ = 0;

      customerDemand[i][d].probability_ = 1.0/(2.0*spread[i] +1.0);
      //keep tracks of maximum possible demand
      if(customerDemand[i][d].demand_ > maxDmnd)
	maxDmnd = customerDemand[i][d].demand_;
    }
  }

  //If given as input parameter, set the capacity equal to the command line value.
  if( control.capacityExists() ) {
    capacity = control.getCapacity();
    if (capacity < maxDmnd){ cerr << "Error: vehicle capacity given in input from command line is too small. Vehicle capacity must be bigger than the maximum customer demand: " << maxDmnd << ". Exit" << endl;
    exit(-1);
    }
  }
  //Else read the capacity from the input file.
  else
    ifs >> capacity;


#ifdef DEBUG  
  //Print out some stats to verify initialization.
  cout << "# Problem data:" << endl;  
  cout << "# numberOfCustomers (depot incl.) " << numberOfCustomers << endl; 
  cout << "# total average demand " << averageDmnd << endl;
  cout << "# capacity " << capacity << endl;
#endif
  /*
  for(int i=0; i<numberOfCustomers; i++){
    cout << i << " ";
    cout << xyCustomers[i][0] << " ";
    cout << xyCustomers[i][1] << " ";
    cout << avgDmnd[i] << " ";
    cout << spread[i] << endl;
    for(int j=0; j<numberOfCustomers; j++)
      cout << distanceMatrix[i][j] << " "; 
    cout << endl;
    for(int d=0; d<2*spread[i]+1; d++)
      cout << customerDemand[i][d].demand_ << " " << customerDemand[i][d].probability_ << " ";
    cout << endl; 
  }
  */

}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人app在线观看| 26uuu亚洲综合色欧美| 在线日韩一区二区| 99久久er热在这里只有精品15| 成人免费福利片| 成人永久免费视频| 成人动漫av在线| 99视频国产精品| 99久久国产综合色|国产精品| 96av麻豆蜜桃一区二区| 91理论电影在线观看| 91香蕉视频黄| 欧美午夜影院一区| 7777精品伊人久久久大香线蕉的| 在线成人午夜影院| 欧美大片一区二区| 国产网红主播福利一区二区| 欧美高清在线一区二区| 中文字幕亚洲一区二区va在线| 亚洲欧美日韩国产另类专区| 亚洲国产一区二区三区| 亚洲成人av一区二区| 久久精品72免费观看| 国产美女在线精品| av一二三不卡影片| 欧美色综合久久| 精品久久一区二区三区| 国产拍欧美日韩视频二区| 亚洲天堂成人网| 日日欢夜夜爽一区| 国产精品一区二区三区网站| 99视频国产精品| 3d动漫精品啪啪| 久久精品视频在线免费观看| 亚洲人吸女人奶水| 日韩国产精品91| 国产精品一卡二| 日本电影亚洲天堂一区| 欧美一级理论性理论a| 中文字幕乱码日本亚洲一区二区 | 国产免费成人在线视频| 亚洲欧美一区二区三区久本道91| 日韩精品欧美成人高清一区二区| 国产精品一区二区视频| 欧美三级韩国三级日本一级| 2021中文字幕一区亚洲| 一区二区三区欧美在线观看| 久久精品国产秦先生| jlzzjlzz欧美大全| 91精品国产丝袜白色高跟鞋| 国产精品少妇自拍| 美女一区二区三区在线观看| 91麻豆免费观看| 精品久久久久久最新网址| 亚洲欧美日本在线| 精品一区二区在线看| 日本电影欧美片| 日本一区二区三区视频视频| 日韩精品电影一区亚洲| 99在线精品免费| 精品国产电影一区二区| 亚洲一区二区黄色| 国产成人啪午夜精品网站男同| 欧美日韩大陆一区二区| 国产精品国产三级国产aⅴ入口 | 91视频在线观看免费| 欧美va亚洲va| 亚洲国产成人91porn| 97se亚洲国产综合在线| 久久久一区二区三区| 青青草91视频| 欧美日韩在线观看一区二区| 亚洲婷婷国产精品电影人久久| 国产一二精品视频| 日韩欧美久久久| 亚洲午夜精品久久久久久久久| 成人深夜福利app| 久久亚洲春色中文字幕久久久| 视频一区欧美精品| 色婷婷综合久久| 亚洲色图视频免费播放| 懂色中文一区二区在线播放| 精品嫩草影院久久| 日韩精品一区第一页| 在线精品观看国产| 亚洲色图一区二区三区| 国产成人激情av| 久久免费偷拍视频| 精品一区二区在线视频| 日韩免费福利电影在线观看| 日韩精品欧美精品| 欧美区视频在线观看| 亚洲成人av中文| 7777精品伊人久久久大香线蕉最新版| 亚洲v日本v欧美v久久精品| 91国偷自产一区二区使用方法| 亚洲视频中文字幕| 波多野结衣中文字幕一区二区三区| 久久精品亚洲一区二区三区浴池| 国产精品主播直播| 国产欧美中文在线| www.亚洲国产| 中文字幕一区二区三区不卡在线| 成人av在线一区二区| 国产精品久久三| 99久久精品一区二区| 最新中文字幕一区二区三区| 91丝袜美腿高跟国产极品老师| 亚洲视频在线一区二区| 99re亚洲国产精品| 亚洲精品亚洲人成人网| 欧美性猛交xxxxxxxx| 亚洲大片免费看| 在线不卡欧美精品一区二区三区| 视频一区二区三区在线| 日韩欧美精品在线视频| 久久99久久99精品免视看婷婷| 亚洲精品一区二区三区在线观看| 国内精品不卡在线| 国产精品美女久久久久久久久久久| 94色蜜桃网一区二区三区| 亚洲五月六月丁香激情| 7777精品伊人久久久大香线蕉完整版| 久久不见久久见中文字幕免费| 久久这里只有精品视频网| 成人一级片在线观看| 亚洲精品乱码久久久久久日本蜜臀| 在线免费观看日本一区| 日韩国产高清影视| 国产视频一区不卡| 色婷婷综合视频在线观看| 日韩国产在线一| 久久久综合网站| 色婷婷综合久久久久中文 | 久久疯狂做爰流白浆xx| 欧美韩日一区二区三区| 日本精品裸体写真集在线观看| 视频精品一区二区| 久久一区二区三区四区| 91丨porny丨户外露出| 日韩专区中文字幕一区二区| 久久久美女毛片| 日本久久一区二区三区| 日韩高清国产一区在线| 国产日韩欧美一区二区三区乱码| 色一情一伦一子一伦一区| 日本欧美一区二区在线观看| 日本一区二区三级电影在线观看| 欧美午夜电影在线播放| 国产一区在线观看麻豆| 亚洲精品一二三| 久久嫩草精品久久久久| 欧美日韩亚洲国产综合| 国产成人午夜视频| 日韩va欧美va亚洲va久久| 国产精品你懂的在线欣赏| 5858s免费视频成人| k8久久久一区二区三区| 久久成人羞羞网站| 亚洲精品伦理在线| 国产日产欧产精品推荐色| 欧美综合久久久| 国产suv精品一区二区三区| 午夜激情久久久| 国产精品高潮呻吟久久| 日韩欧美一区在线| 91久久精品网| av中文字幕不卡| 久久99热狠狠色一区二区| 亚洲欧美视频一区| 国产欧美va欧美不卡在线| 日韩手机在线导航| 欧美偷拍一区二区| 成人av电影免费在线播放| 精品一区二区成人精品| 亚洲成人精品在线观看| 亚洲欧洲国产日本综合| 久久久久久久久99精品| 日韩亚洲欧美一区二区三区| 欧美中文字幕久久| 成人网男人的天堂| 国产精品一区二区久激情瑜伽 | 91网站最新地址| 成人妖精视频yjsp地址| 久久国产夜色精品鲁鲁99| 视频一区欧美精品| 亚洲bt欧美bt精品| 亚洲另类中文字| 亚洲免费av网站| 亚洲欧美怡红院| 欧美极品另类videosde| 久久婷婷色综合| 欧美xxxxx牲另类人与| 欧美一卡二卡三卡四卡| 欧美日韩久久久一区| 欧美亚洲国产bt| 欧美综合亚洲图片综合区| 欧洲一区二区三区在线| 欧美亚洲愉拍一区二区| 欧美伊人精品成人久久综合97|