日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

八皇后问题和八数码问题的最陡上升爬山法、首选爬山法、随机重启爬山法、模拟退火算法的分析和实现

發(fā)布時間:2025/3/11 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 八皇后问题和八数码问题的最陡上升爬山法、首选爬山法、随机重启爬山法、模拟退火算法的分析和实现 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

對經(jīng)典算法的問題的回顧與感想

對八皇后問題和八數(shù)碼問題分別用最陡上升爬山法、首選爬山法、隨機重啟爬山法、模擬退火算法來實現(xiàn),并且分析他們的性能。


分析

要求實現(xiàn)的各個算法是有共同點的,比如,八皇后問題相關算法擁有相同的狀態(tài)空間,每個算法都有從當前狀態(tài)獲取下一狀態(tài)的需求,各個算法細節(jié)不同,共同點是,它們都是算法。
基于這樣的想法,我們可以將代碼劃分為3層:


運行示例

代碼比較長,附在最后面,讀者基于上述的思路是不難看懂的。
我們默認讀者已經(jīng)知道這幾個算法的思路,代碼直接給出實現(xiàn)。如果不懂,請翻閱人工智能課本,里面有講。

圖1,八數(shù)碼問題的交互界面

圖2,八皇后問題的交互界面

圖3 輸出界面示例


結果分析

為了便于研究,我們首先定義三個指標,分別是:
①因變1:算法找到解的成功率;
②因變2:算法找到的解的平均路徑長度
③因變3:算法找到解的平均耗散,用搜索的結點數(shù)衡量

對八皇后的結果分析


觀察表1,我們可以發(fā)現(xiàn)如下對八皇后問題的有趣結論:
(1)在八皇后問題中,當隨機測例數(shù)增加,最陡上升爬山法和首選爬山法的成功率都收斂到0.142左右,與書本結論吻合。
(2)最陡上升爬山法的解的平均路徑長度收斂到0.58左右,而首選爬山是0.83左右。這說明最陡爬山法的平均走了更短的路徑到達全局最優(yōu)解。
(3)雖然最陡上山法的平均路徑長度更短,但是搜索耗散卻比首選爬山法多,原因是,為了得到最陡的子結點,需要探查所有的相鄰子節(jié)點。反應在數(shù)據(jù)上是,最陡上山法的解的平均耗散率收斂到32左右,而首選爬山法僅為19左右。
(4)隨機重啟爬山法比最陡上升法和首選爬山法的成功率兜大大提高,重啟次數(shù)為5,隨機測例10000時,成功率高達0.6,約為前二者算法的4倍。但是也付出了更大的代價,平均解長度是最陡上升法的18.4倍,是首選爬山法的12.7倍;解的平均耗散度是最陡爬山法的17倍,是首選爬山法的28.4倍。
(5)隨機重啟爬山法的成功率隨初始溫度的增加而上升。當重啟次數(shù)為0時,退化為首選爬山法,成功率、解長度、解耗散度都和首選爬山法接近。隨著重啟次數(shù)增加,成功率也大大上升,當重啟次數(shù)為7時,成功率為0.7092,是重啟次數(shù)為0的4.96倍,相應地,解長度和解耗散也大大增加。
(6)模擬退火算法隨起始溫度上升,成功率也上升。理論上分析,當起始溫度足夠高,退火過程足夠長的時候,成功率可以接近1。但是其開銷也會變得極大,0.43成功率的退火算法的解長度是0.46成功率退火算法的3706倍,而解耗散是146.5倍。

對八數(shù)碼問題的結果分析


觀察表2,我們可以發(fā)現(xiàn)如下對八數(shù)碼問題的有趣結論:
(1)與八皇后問題類似,最陡上升和首選爬山法收斂到了接近的成功率,此處是0.4左右。但是解長度和解耗散并沒有八皇后問題大,可能的原因是,八數(shù)碼問題的相鄰子結點空間遠比八皇后問題大。
(2)這里沒有使用隨機重啟算法,因為八數(shù)碼問題關心解路徑,如果使用了隨機重啟算法,則違反了規(guī)則。
(3)初始狀態(tài)是通過目標隨機打亂得來的,先隨機取上限次數(shù)一下的打亂數(shù)x,然后隨機方向移動白塊x次。我們發(fā)現(xiàn),打亂步數(shù)上限的多少,對成功率的影響并不大,無論最陡爬山算法,首選爬山算法,模擬退火算法都如此。可能的原因是,在打亂次數(shù)上限很小的時候,成功率就已經(jīng)收斂了。
(4)模擬退火算法在八數(shù)碼問題和八皇后問題的表現(xiàn)類似。都隨著初始溫度的上升而上升,同時解長度和解耗散急劇增大。理論上,當初始溫度足夠高,成功率會逼近1。

代碼

由于實在太多,我就不逐行解釋。讀者把握分析時的思路,應該不難讀懂。

//***************************************************** // eightQueue.hpp // 包括八皇后問題的eightQueueNode類和eightQueueNodeFactory的實現(xiàn) //***************************************************** #include <iostream> #include <stdlib.h> #include <time.h> class eightQueueNode { public:int arr[8];eightQueueNode(int a,int b, int c, int d, int e, int f, int g, int h){arr[0] = a;arr[1] = b;arr[2] = c;arr[3] = d;arr[4] = e;arr[5] = f;arr[6] = g;arr[7] = h;}eightQueueNode(const eightQueueNode& node) {arr[0] = node.arr[0];arr[1] = node.arr[1];arr[2] = node.arr[2];arr[3] = node.arr[3];arr[4] = node.arr[4];arr[5] = node.arr[5];arr[6] = node.arr[6];arr[7] = node.arr[7];}~eightQueueNode(){}bool operator==(const eightQueueNode& node) {return (this->arr[0] == node.arr[0]) && (this->arr[1] == node.arr[1]) && (this->arr[2] == node.arr[2])&& (this->arr[3] == node.arr[3]) && (this->arr[4] == node.arr[4]) && (this->arr[5] == node.arr[5])&& (this->arr[6] == node.arr[6]) && (this->arr[7] == node.arr[7]);} };class eightQueueNodeFactory{private:int ranNum(){return rand() % 8;}bool isTheArrayAllTrue(bool isAllCheck[64]) {for(int i = 0; i < 64; i++) {if(isAllCheck[i] == false) {return false;}}return true;}public:eightQueueNodeFactory(){srand((unsigned)time(NULL));}eightQueueNode getARandomNode() {return eightQueueNode(ranNum(),ranNum(),ranNum(),ranNum(),ranNum(),ranNum(),ranNum(),ranNum());}int evaluate(const eightQueueNode& node) {int numOfAttack = 0;for(int i = 0; i < 7; i++) {for(int j = i + 1; j < 8; j++) {if (node.arr[i] == node.arr[j] || (node.arr[i]-node.arr[j]) == (i-j) || (node.arr[i]-node.arr[j]) == (j-i)) {numOfAttack++;}}}return numOfAttack;}int getBestNextNode(eightQueueNode& node) {eightQueueNode ans = node;eightQueueNode tmp = node;int costOfSearch = 0;for(int i = 0; i < 64; i++) {tmp = node;tmp.arr[i/8] = i % 8;if(evaluate(tmp) < evaluate(ans)) {ans = tmp;} else if(evaluate(tmp) == evaluate(ans)) {if(rand() / double(RAND_MAX) > 0.5) {ans = tmp;}}}node = ans;return 56;}// the input node is confirmed to be not the bestint getNextBetterNode(eightQueueNode& node) {bool isAllCheck[64];for(int i = 0; i < 64; i++) isAllCheck[i] = false;eightQueueNode tmp = node;int costOfSearch = 1;while(evaluate(tmp) >= evaluate(node)) {// 子節(jié)點全部搜索過,都比當前差if(isTheArrayAllTrue(isAllCheck)) return costOfSearch;// 初始化,找下一鄰居tmp = node;int a = rand() % 64;isAllCheck[a] = true;tmp.arr[a/8] = a % 8;costOfSearch++;if(tmp == node) {continue;}}node = tmp;return costOfSearch;}int getARandomNeighbour(eightQueueNode& node) {eightQueueNode tmp = node;int cost = 0;while(node == tmp) {cost++;int a = rand() % 64;tmp.arr[a/8] = a % 8;}node = tmp;return cost;} };
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
//*************************************** // eightQueueRunner.cpp // 包括八皇后問題的各個算法和簡單交互界面實現(xiàn) //*************************************** #include "eightQueue.hpp" #include <iostream> #include <math.h>using namespace std; eightQueueNodeFactory factory;#define NUM_OF_LOOP 10000 #define NUM_OF_REBOOT 0 #define BEGIN_TEMP 10000 #define STOP_TEMP 1void mostSteepClimbing(); void firstSeclectionClimbing(); void randomRebootClimbing(); void simulatedAnnealing();int main() {int choice = 0;do{cout << endl;cout << "The Eight Queue Problem:" << endl;cout << " 0 -- most steep climbing" << endl;cout << " 1 -- first selection climbing" << endl;cout << " 2 -- random reboot climbing" << endl;cout << " 3 -- stimulated annealing" << endl;cout << "please input your choice: ";cin >> choice;if (choice == -1) break;switch(choice) {case 0:mostSteepClimbing();break;case 1:firstSeclectionClimbing();break;case 2:randomRebootClimbing();break;case 3:simulatedAnnealing();break;default:break;}}while(true);return 0; }void mostSteepClimbing() {int sumOfsuccess = 0, sumOfFailure = 0;double theSumOfCostOfSearchOfSuccess = 0, theSumLengthOfSolutionOfSuccess = 0;for(int i = 0; i < NUM_OF_LOOP; i++) {bool success = false;int cost = 0, lenOfRoute = 0;eightQueueNode curState = factory.getARandomNode();eightQueueNode tmp = curState;while(true) {// if satisfied, then breakif (factory.evaluate(curState) == 0) {success = true;break;}lenOfRoute++;cost += factory.getBestNextNode(tmp);if(factory.evaluate(tmp) >= factory.evaluate(curState)) {break;} else {curState = tmp;}}if(success) {sumOfsuccess++;theSumOfCostOfSearchOfSuccess += cost;theSumLengthOfSolutionOfSuccess += lenOfRoute;} else {sumOfFailure++;}// outputcout << "case " << i << " cost: " << cost << " " << "lengthOfSolution: " << lenOfRoute << " ";if(success){cout << "success ";} else {cout << "failure ";}cout << endl;}cout << "Sum of success: " << sumOfsuccess << endl;cout << "Sum of failure " << sumOfFailure << endl;cout << "Rate of success " << sumOfsuccess/((double)(sumOfFailure + sumOfsuccess)) << endl; cout << "The average solution length of success:" << theSumLengthOfSolutionOfSuccess/NUM_OF_LOOP << endl;cout << "The average cost of search of success:" << theSumOfCostOfSearchOfSuccess/NUM_OF_LOOP << endl; return; }void firstSeclectionClimbing() {int sumOfsuccess = 0, sumOfFailure = 0;double theSumOfCostOfSearchOfSuccess = 0, theSumLengthOfSolutionOfSuccess = 0;for(int i = 0; i < NUM_OF_LOOP; i++) {bool success = false;int cost = 0, lenOfRoute = 0;eightQueueNode curState = factory.getARandomNode();eightQueueNode tmp = curState;while(true) {// if satisfied, then breakif (factory.evaluate(curState) == 0) {success = true;break;}lenOfRoute++;cost += factory.getNextBetterNode(tmp);if(factory.evaluate(tmp) >= factory.evaluate(curState)) {break;} else {curState = tmp;}}if(success) {sumOfsuccess++;theSumOfCostOfSearchOfSuccess += cost;theSumLengthOfSolutionOfSuccess += lenOfRoute;} else {sumOfFailure++;}// outputcout << "case " << i << " cost: " << cost << " " << "lengthOfSolution: " << lenOfRoute << " ";if(success){cout << "success ";} else {cout << "failure ";}cout << endl;}cout << "Sum of success: " << sumOfsuccess << endl;cout << "Sum of failure " << sumOfFailure << endl;cout << "Rate of success " << sumOfsuccess/((double)(sumOfFailure + sumOfsuccess)) << endl; cout << "The average solution length of success:" << theSumLengthOfSolutionOfSuccess/NUM_OF_LOOP << endl;cout << "The average cost of search of success:" << theSumOfCostOfSearchOfSuccess/NUM_OF_LOOP << endl; return; }void randomRebootClimbing() {int sumOfsuccess = 0, sumOfFailure = 0;double theSumOfCostOfSearchOfSuccess = 0, theSumLengthOfSolutionOfSuccess = 0;for(int i = 0; i < NUM_OF_LOOP; i++) {bool success = false;int cost = 0, lenOfRoute = 0, numOfReboot = NUM_OF_REBOOT;eightQueueNode curState = factory.getARandomNode();eightQueueNode tmp = curState;while(true) {// if satisfied, then breakif (factory.evaluate(curState) == 0) {success = true;break;}lenOfRoute++;cost += factory.getNextBetterNode(tmp);if(factory.evaluate(tmp) >= factory.evaluate(curState)) {if(numOfReboot > 0) {numOfReboot--;curState = factory.getARandomNode();tmp = curState;} else {break;}} else {curState = tmp;}}if(success) {sumOfsuccess++;theSumOfCostOfSearchOfSuccess += cost;theSumLengthOfSolutionOfSuccess += lenOfRoute;} else {sumOfFailure++;}// outputcout << "case " << i << " cost: " << cost << " " << "lengthOfSolution: " << lenOfRoute << " ";if(success){cout << "success ";} else {cout << "failure ";}cout << endl;}cout << "Sum of success: " << sumOfsuccess << endl;cout << "Sum of failure " << sumOfFailure << endl;cout << "Rate of success " << sumOfsuccess/((double)(sumOfFailure + sumOfsuccess)) << endl; cout << "The average solution length of success:" << theSumLengthOfSolutionOfSuccess/NUM_OF_LOOP << endl;cout << "The average cost of search of success:" << theSumOfCostOfSearchOfSuccess/NUM_OF_LOOP << endl; return; }void simulatedAnnealing() {int sumOfsuccess = 0, sumOfFailure = 0;double theSumOfCostOfSearchOfSuccess = 0, theSumLengthOfSolutionOfSuccess = 0;for(int i = 0; i < NUM_OF_LOOP; i++) {bool success = false;int cost = 0, lenOfRoute = 0;double curTemp = BEGIN_TEMP;eightQueueNode curState = factory.getARandomNode();eightQueueNode tmp = curState;while(true) {// if satisfied, then breakif (factory.evaluate(curState) == 0) {success = true;break;} else if(curTemp < STOP_TEMP){// 溫度過低,則停止break;}// 走一步,則溫度下降lenOfRoute++;curTemp -= 1;cost += factory.getARandomNeighbour(tmp);int deltaOfEvalutaion = factory.evaluate(tmp) - factory.evaluate(curState);if(deltaOfEvalutaion >= 0) {// 根據(jù)溫度差來決定是否接受double probility = exp(curTemp/(deltaOfEvalutaion));if(rand() / double(RAND_MAX) < deltaOfEvalutaion) {curState = tmp;}} else {curState = tmp;}}if(success) {sumOfsuccess++;theSumOfCostOfSearchOfSuccess += cost;theSumLengthOfSolutionOfSuccess += lenOfRoute;} else {sumOfFailure++;}// outputcout << "case " << i << " cost: " << cost << " " << "lengthOfSolution: " << lenOfRoute << " ";if(success){cout << "success ";} else {cout << "failure ";}cout << endl;}cout << "Sum of success: " << sumOfsuccess << endl;cout << "Sum of failure " << sumOfFailure << endl;cout << "Rate of success " << sumOfsuccess/((double)(sumOfFailure + sumOfsuccess)) << endl; cout << "The average solution length of success:" << theSumLengthOfSolutionOfSuccess/NUM_OF_LOOP << endl;cout << "The average cost of search of success:" << theSumOfCostOfSearchOfSuccess/NUM_OF_LOOP << endl; return; }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143
  • 144
  • 145
  • 146
  • 147
  • 148
  • 149
  • 150
  • 151
  • 152
  • 153
  • 154
  • 155
  • 156
  • 157
  • 158
  • 159
  • 160
  • 161
  • 162
  • 163
  • 164
  • 165
  • 166
  • 167
  • 168
  • 169
  • 170
  • 171
  • 172
  • 173
  • 174
  • 175
  • 176
  • 177
  • 178
  • 179
  • 180
  • 181
  • 182
  • 183
  • 184
  • 185
  • 186
  • 187
  • 188
  • 189
  • 190
  • 191
  • 192
  • 193
  • 194
  • 195
  • 196
  • 197
  • 198
  • 199
  • 200
  • 201
  • 202
  • 203
  • 204
  • 205
  • 206
  • 207
  • 208
  • 209
  • 210
  • 211
  • 212
  • 213
  • 214
  • 215
  • 216
  • 217
  • 218
  • 219
  • 220
  • 221
  • 222
  • 223
  • 224
  • 225
  • 226
  • 227
  • 228
  • 229
  • 230
  • 231
  • 232
  • 233
  • 234
  • 235
  • 236
  • 237
  • 238
  • 239
  • 240
  • 241
  • 242
  • 243
  • 244
  • 245
  • 246
  • 247
  • 248
  • 249
  • 250
  • 251
  • 252
  • 253
  • 254
  • 255
  • 256
  • 257
  • 258
  • 259
  • 260
  • 261
  • 262
  • 263
  • 264
  • 265
//*************************************************************** // eightDigit.hpp // 包括八數(shù)碼問題的eightDigitNode類和eightDigitFactory類的實現(xiàn) // ************************************************************** #include <iostream> #include <stdlib.h> #include <time.h> #include <math.h>#define LOOP_OF_SHUFFLE 50class eightDigitNode { public:int arr[9];int blank_x = 2, blank_y = 2;eightDigitNode(){for(int i = 0; i < 8; i++) {arr[i] = i+1;}arr[8] = 0;}~eightDigitNode(){}eightDigitNode(const eightDigitNode& node) {arr[0] = node.arr[0];arr[1] = node.arr[1];arr[2] = node.arr[2];arr[3] = node.arr[3];arr[4] = node.arr[4];arr[5] = node.arr[5];arr[6] = node.arr[6];arr[7] = node.arr[7];arr[8] = node.arr[8];blank_x = node.blank_x;blank_y = node.blank_y;}bool operator==(const eightDigitNode& node) {for(int i = 0; i < 8; i++) {if(arr[i] != node.arr[i]) return false;}return true;}bool goLeft() {if(blank_y == 0) {return false;} else {arr[blank_x*3+blank_y] = arr[blank_x*3+blank_y-1];arr[blank_x*3+blank_y-1] = 0;blank_y--;return true;}}bool goRight() {if(blank_y == 2) {return false;} else {arr[blank_x*3+blank_y] = arr[blank_x*3+blank_y+1];arr[blank_x*3+blank_y+1] = 0;blank_y++;return true;}}bool goUp() {if(blank_x == 0) {return false;} else {arr[blank_x*3+blank_y] = arr[(blank_x-1)*3+blank_y];arr[(blank_x-1)*3+blank_y] = 0;blank_x--;return true;}}bool goDown() {if(blank_x == 2) {return false;} else {arr[blank_x*3+blank_y] = arr[(blank_x+1)*3+blank_y];arr[(blank_x+1)*3+blank_y] = 0;blank_x++; return true;}} };
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
class eightDigitNodeFactory{ private:int getManhattanDistian(const int& src, const int& target) {return abs(src%3 - target%3) + abs(src/3 - target/3); }int getNumOfWrongNumber(const eightDigitNode& node) {int res = 0;for(int i = 0; i < 8; i++) {if (node.arr[i] != i+1) res++;}if(node.arr[8] != 0) res++;return res; }bool getANeighbourNode(int direction, eightDigitNode& node) {switch(direction) {case 0: return node.goLeft();case 1: return node.goUp();case 2: return node.goRight();default:return node.goDown();}}bool isTheArrayAllTrue(bool isAllCheck[4]) {for(int i = 0; i < 4; i++) {if(isAllCheck[i] == false) {return false;}}return true;}public:eightDigitNodeFactory() {srand((unsigned)time(NULL));}eightDigitNode getARandomNode() {eightDigitNode output;int timesOfShuffle = rand() % LOOP_OF_SHUFFLE;while(timesOfShuffle--) {while(!getANeighbourNode(rand()%4, output));}return output;}int evaluate(const eightDigitNode& node) {eightDigitNode tmp;int distanceToTargetState = 0;for(int i = 0; i < 9; i++) {int j = 0;while(tmp.arr[j] != node.arr[i]) {j++;}distanceToTargetState += getManhattanDistian(i, j);}return distanceToTargetState + 3*getNumOfWrongNumber(node);}int getBestNextNode(eightDigitNode& node) {eightDigitNode tmp = node, ans = node;for(int i = 0; i < 4; i++) {tmp = node;if(getANeighbourNode(i, tmp) && evaluate(tmp) < evaluate(ans)) {ans = tmp;} else if(evaluate(tmp) == evaluate(ans)) {if(rand() / double(RAND_MAX) > 0.5) {ans = tmp;}}}node = ans;return 4;}int getNextBetterNode(eightDigitNode& node) {bool isAllCheck[4];for(int i = 0; i < 4; i++) {isAllCheck[i] = false;}eightDigitNode tmp = node;int costOfSearch = 1;while(evaluate(tmp) >= evaluate(node)) {// 子節(jié)點全部搜索過,都比當前差if(isTheArrayAllTrue(isAllCheck)) return costOfSearch;// 初始化,找下一鄰居tmp = node;int a = rand() % 4;isAllCheck[a] = true;getANeighbourNode(a, tmp);costOfSearch++;if(tmp == node) {continue;}}node = tmp;return costOfSearch;}int getARandomNeighbour(eightDigitNode& node) {int costOfSearch = 0;eightDigitNode tmp = node;while(!getANeighbourNode(rand()%4, tmp)) {costOfSearch++;tmp = node;}node = tmp;return costOfSearch;} };
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
//********************************************* // eightDigitRunner.cpp // 包括八數(shù)碼問題各算法的和簡單交互界面實現(xiàn) //******************************************** #include "eightDigit.hpp" #include <iostream> #include <math.h>using namespace std; eightDigitNodeFactory factory;#define NUM_OF_LOOP 10000 #define NUM_OF_REBOOT 7 #define BEGIN_TEMP 100000 #define STOP_TEMP 1void mostSteepClimbing(); void firstSeclectionClimbing(); void randomRebootClimbing(); void simulatedAnnealing();int main() {int choice = 0;do{cout << endl;cout << "The Eight Digit Problem:" << endl;cout << " 0 -- most steep climbing" << endl;cout << " 1 -- first selection climbing" << endl;cout << " 2 -- random reboot climbing" << endl;cout << " 3 -- stimulated annealing" << endl;cout << "please input your choice: ";cin >> choice;if (choice == -1) break;switch(choice) {case 0:mostSteepClimbing();break;case 1:firstSeclectionClimbing();break;case 2:randomRebootClimbing();break;case 3:simulatedAnnealing();break;default:break;}}while(true);return 0; }void mostSteepClimbing() {int sumOfsuccess = 0, sumOfFailure = 0;double theSumOfCostOfSearchOfSuccess = 0, theSumLengthOfSolutionOfSuccess = 0;for(int i = 0; i < NUM_OF_LOOP; i++) {bool success = false;int cost = 0, lenOfRoute = 0;eightDigitNode curState = factory.getARandomNode();eightDigitNode tmp = curState;while(true) {// if satisfied, then breakif (factory.evaluate(curState) == 0) {success = true;break;}lenOfRoute++;cost += factory.getBestNextNode(tmp);if(factory.evaluate(tmp) >= factory.evaluate(curState)) {break;} else {curState = tmp;}}if(success) {sumOfsuccess++;theSumOfCostOfSearchOfSuccess += cost;theSumLengthOfSolutionOfSuccess += lenOfRoute;} else {sumOfFailure++;}// outputcout << "case " << i << " cost: " << cost << " " << "lengthOfSolution: " << lenOfRoute << " ";if(success){cout << "success ";} else {cout << "failure ";}cout << endl;}cout << "Sum of success: " << sumOfsuccess << endl;cout << "Sum of failure " << sumOfFailure << endl;cout << "Rate of success " << sumOfsuccess/((double)(sumOfFailure + sumOfsuccess)) << endl;cout << "The average solution length of success:" << theSumLengthOfSolutionOfSuccess/NUM_OF_LOOP << endl;cout << "The average cost of search of success:" << theSumOfCostOfSearchOfSuccess/NUM_OF_LOOP << endl; return; }void firstSeclectionClimbing() {int sumOfsuccess = 0, sumOfFailure = 0;double theSumOfCostOfSearchOfSuccess = 0, theSumLengthOfSolutionOfSuccess = 0;for(int i = 0; i < NUM_OF_LOOP; i++) {bool success = false;int cost = 0, lenOfRoute = 0;eightDigitNode curState = factory.getARandomNode();eightDigitNode tmp = curState;while(true) {// if satisfied, then breakif (factory.evaluate(curState) == 0) {success = true;break;}lenOfRoute++;cost += factory.getNextBetterNode(tmp);if(factory.evaluate(tmp) >= factory.evaluate(curState)) {break;} else {curState = tmp;}}if(success) {sumOfsuccess++;theSumOfCostOfSearchOfSuccess += cost;theSumLengthOfSolutionOfSuccess += lenOfRoute;} else {sumOfFailure++;}// outputcout << "case " << i << " cost: " << cost << " " << "lengthOfSolution: " << lenOfRoute << " ";if(success){cout << "success ";} else {cout << "failure ";}cout << endl;}cout << "Sum of success: " << sumOfsuccess << endl;cout << "Sum of failure " << sumOfFailure << endl;cout << "Rate of success " << sumOfsuccess/((double)(sumOfFailure + sumOfsuccess)) << endl; cout << "The average solution length of success:" << theSumLengthOfSolutionOfSuccess/NUM_OF_LOOP << endl;cout << "The average cost of search of success:" << theSumOfCostOfSearchOfSuccess/NUM_OF_LOOP << endl; return; } void randomRebootClimbing() {int sumOfsuccess = 0, sumOfFailure = 0;double theSumOfCostOfSearchOfSuccess = 0, theSumLengthOfSolutionOfSuccess = 0;for(int i = 0; i < NUM_OF_LOOP; i++) {bool success = false;int cost = 0, lenOfRoute = 0;eightDigitNode curState = factory.getARandomNode();eightDigitNode tmp = curState;while(true) {// if satisfied, then breakif (factory.evaluate(curState) == 0) {success = true;break;}lenOfRoute++;cost += factory.getNextBetterNode(tmp);if(factory.evaluate(tmp) >= factory.evaluate(curState)) {break;} else {curState = tmp;}}if(success) {sumOfsuccess++;theSumOfCostOfSearchOfSuccess += cost;theSumLengthOfSolutionOfSuccess += lenOfRoute;} else {sumOfFailure++;}// outputcout << "case " << i << " cost: " << cost << " " << "lengthOfSolution: " << lenOfRoute << " ";if(success){cout << "success ";} else {cout << "failure ";}cout << endl;}cout << "Sum of success: " << sumOfsuccess << endl;cout << "Sum of failure " << sumOfFailure << endl;cout << "Rate of success " << sumOfsuccess/((double)(sumOfFailure + sumOfsuccess)) << endl; cout << "The average solution length of success:" << theSumLengthOfSolutionOfSuccess/NUM_OF_LOOP << endl;cout << "The average cost of search of success:" << theSumOfCostOfSearchOfSuccess/NUM_OF_LOOP << endl; return; } void simulatedAnnealing() {int sumOfsuccess = 0, sumOfFailure = 0;double theSumOfCostOfSearchOfSuccess = 0, theSumLengthOfSolutionOfSuccess = 0;for(int i = 0; i < NUM_OF_LOOP; i++) {bool success = false;int cost = 0, lenOfRoute = 0;double curTemp = BEGIN_TEMP;eightDigitNode curState = factory.getARandomNode();eightDigitNode tmp = curState;while(true) {// if satisfied, then breakif (factory.evaluate(curState) == 0) {success = true;break;} else if(curTemp < STOP_TEMP){// 溫度過低,則停止break;}// 走一步,則溫度下降lenOfRoute++;curTemp -= 1;cost += factory.getARandomNeighbour(tmp);int deltaOfEvalutaion = factory.evaluate(tmp) - factory.evaluate(curState);if(deltaOfEvalutaion >= 0) {// 根據(jù)溫度差來決定是否接受double probility = exp(curTemp/(deltaOfEvalutaion));if(rand() / double(RAND_MAX) < deltaOfEvalutaion) {curState = tmp;}} else {curState = tmp;}}if(success) {sumOfsuccess++;theSumOfCostOfSearchOfSuccess += cost;theSumLengthOfSolutionOfSuccess += lenOfRoute;} else {sumOfFailure++;}// outputcout << "case " << i << " cost: " << cost << " " << "lengthOfSolution: " << lenOfRoute << " ";if(success){cout << "success ";} else {cout << "failure ";}cout << endl;}cout << "Sum of success: " << sumOfsuccess << endl;cout << "Sum of failure " << sumOfFailure << endl;cout << "Rate of success " << sumOfsuccess/((double)(sumOfFailure + sumOfsuccess)) << endl; cout << "The average solution length of success:" << theSumLengthOfSolutionOfSuccess/NUM_OF_LOOP << endl;cout << "The average cost of search of success:" << theSumOfCostOfSearchOfSuccess/NUM_OF_LOOP << endl; return;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143
  • 144
  • 145
  • 146
  • 147
  • 148
  • 149
  • 150
  • 151
  • 152
  • 153
  • 154
  • 155
  • 156
  • 157
  • 158
  • 159
  • 160
  • 161
  • 162
  • 163
  • 164
  • 165
  • 166
  • 167
  • 168
  • 169
  • 170
  • 171
  • 172
  • 173
  • 174
  • 175
  • 176
  • 177
  • 178
  • 179
  • 180
  • 181
  • 182
  • 183
  • 184
  • 185
  • 186
  • 187
  • 188
  • 189
  • 190
  • 191
  • 192
  • 193
  • 194
  • 195
  • 196
  • 197
  • 198
  • 199
  • 200
  • 201
  • 202
  • 203
  • 204
  • 205
  • 206
  • 207
  • 208
  • 209
  • 210
  • 211
  • 212
  • 213
  • 214
  • 215
  • 216
  • 217
  • 218
  • 219
  • 220
  • 221
  • 222
  • 223
  • 224
  • 225
  • 226
  • 227
  • 228
  • 229
  • 230
  • 231
  • 232
  • 233
  • 234
  • 235
  • 236
  • 237
  • 238
  • 239
  • 240
  • 241
  • 242
  • 243
  • 244
  • 245
  • 246
  • 247
  • 248
  • 249
  • 250
  • 251
  • 252
  • 253
  • 254
  • 255
  • 256
<link href="https://csdnimg.cn/release/phoenix/mdeditor/markdown_views-258a4616f7.css" rel="stylesheet"></div>

總結

以上是生活随笔為你收集整理的八皇后问题和八数码问题的最陡上升爬山法、首选爬山法、随机重启爬山法、模拟退火算法的分析和实现的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內容還不錯,歡迎將生活随笔推薦給好友。

亚洲视频在线免费看 | 欧美一级淫片videoshd | 国产成人亚洲在线电影 | 国产精品嫩草影视久久久 | 少妇搡bbbb搡bbb搡aa | 免费在线观看一级片 | 高清视频一区 | 男女啪啪视屏 | 国产一区二区在线观看免费 | 国产四虎在线 | 日本精品久久久久久 | 天天干天天射天天操 | 成人黄色电影在线播放 | 久久久精品高清 | 九九免费精品视频 | 免费观看91 | 国产手机av | 五月天天天操 | 久久天堂亚洲 | 欧美精品在线观看一区 | 久久久免费在线观看 | 天天天天天天操 | 天天玩夜夜操 | 精品国产观看 | 天天爱综合| 天天综合成人网 | 狠狠躁日日躁狂躁夜夜躁 | 夜色成人网 | 麻豆久久精品 | 亚洲精品视频www | 四虎4hu永久免费 | 久久影院一区 | 国产第一页在线播放 | 亚洲男男gaygay无套 | 久久91久久久久麻豆精品 | 亚洲v欧美v国产v在线观看 | 91网页版在线观看 | 91入口在线观看 | 免费黄在线看 | 一区二区三区日韩在线 | 亚洲一级片免费观看 | 国产日韩欧美在线观看视频 | 免费视频国产 | 亚洲少妇影院 | 国产女人18毛片水真多18精品 | 97超碰色偷偷 | 综合铜03 | 91热爆在线观看 | 黄色网www | 天天色天天操综合 | 玖玖视频免费在线 | 亚洲欧美日韩精品久久久 | 在线播放日韩av | 97在线观看免费高清完整版在线观看 | 久久免费试看 | 国内免费久久久久久久久久久 | 99热精品在线观看 | 婷婷久久久 | 国产理伦在线 | 亚洲国产成人精品在线观看 | 成年免费在线视频 | 国产精品久久久久久久久久久久久 | 欧美性黄网官网 | 色综合久久中文字幕综合网 | 婷婷精品国产一区二区三区日韩 | 有没有在线观看av | 精品国产一区二区三区久久久蜜臀 | 五月婷婷开心 | 91免费版在线 | 国产婷婷vvvv激情久 | 亚洲闷骚少妇在线观看网站 | 亚洲高清视频在线播放 | 日韩精品一区二区三区丰满 | 久草爱 | 日韩在线色视频 | 中文字幕丝袜一区二区 | 99r在线观看 | 免费观看一区二区三区视频 | 久久99爱视频 | 国产精品a久久久久 | 日本中文字幕系列 | 国产美女免费观看 | 永久免费在线 | 在线不卡中文字幕播放 | 国产成人精品网站 | 日韩大片免费观看 | 国产日韩精品视频 | 欧美性久久久 | 91精品一区二区三区蜜臀 | aa一级片 | 处女av在线| 国产无遮挡又黄又爽在线观看 | 超碰在线公开免费 | 国产在线观看h | 久久久久久99精品 | 在线国产精品视频 | 18做爰免费视频网站 | 91九色视频在线播放 | 久久综合久久综合九色 | 日本精品中文字幕 | adc在线观看 | 欧美日韩在线网站 | 日日操天天操夜夜操 | 一级做a视频 | 久久成人国产 | 久久精品国产亚洲精品 | 久久成人高清视频 | 97超碰福利久久精品 | 亚洲精品播放 | 午夜色站| 密桃av在线 | a视频在线 | 99久久精品国产亚洲 | 中文字幕一区二区在线观看 | 99精品国产免费久久久久久下载 | 丁香久久| 91在线网址| 亚洲电影影音先锋 | 国产91在线免费视频 | 99久久99久久精品 | 日韩av看片 | 婷婷丁香激情五月 | 性色在线视频 | 日本久久综合网 | 精品国产一区二区三区在线观看 | 最近中文字幕免费观看 | 国产九九九精品视频 | 超碰资源在线 | 91在线文字幕 | 日韩中文字幕在线不卡 | 国产无遮挡又黄又爽馒头漫画 | 国产精品视频免费看 | 欧美精品一区二区在线播放 | 久久综合九色综合欧美就去吻 | 三级黄色欧美 | 99精品久久99久久久久 | 亚洲精品9 | 欧美一区三区四区 | 久久天天草| 亚洲国产精品女人久久久 | 亚洲综合欧美日韩狠狠色 | 国产一区二区在线免费视频 | 亚洲成人在线免费 | 欧美亚洲成人xxx | 欧美网址在线观看 | 成人a在线观看 | 天天综合网天天综合色 | 亚洲综合精品视频 | 久久久性 | 在线观看视频免费大全 | 日韩av快播电影网 | 国产拍揄自揄精品视频麻豆 | 免费观看的av网站 | 亚洲理论视频 | 最近中文字幕完整视频高清1 | 久久久久久久18 | 国内视频一区二区 | 日韩av一区二区在线影视 | 97精品超碰一区二区三区 | 中文在线资源 | 在线精品观看国产 | 久久一二三四 | 91网在线看 | 成全在线视频免费观看 | 日韩av电影手机在线观看 | 久青草视频在线观看 | 99视频国产在线 | 日韩高清精品免费观看 | 久久精品欧美一 | 欧美激情第十页 | 国产亚洲视频中文字幕视频 | 狠狠色丁香婷婷综合 | 国产午夜精品一区 | 91精品免费在线观看 | av大全在线看 | 免费观看一区二区三区视频 | 久久露脸国产精品 | 国产91精品在线播放 | 五月天九九 | 国产香蕉视频 | 久草免费在线观看视频 | 99r国产精品 | 2024国产精品视频 | 91在线国产观看 | www好男人| 中文字幕有码在线播放 | 国产精品大片免费观看 | 色综合天天综合 | 久草在线免费在线观看 | 久久久久激情电影 | 中文字幕在线播放日韩 | 91在线一区二区 | 99久热 | www.狠狠插.com | 在线激情小视频 | 亚洲男男gaygayxxxgv | 九九免费观看全部免费视频 | 成人久久久精品国产乱码一区二区 | 国产在线观看中文字幕 | 奇米网网址 | 三级性生活视频 | 久热av在线| 天天爱天天操天天爽 | 九九久久久久久久久激情 | 黄色www免费| 国内丰满少妇猛烈精品播放 | 久久国产精品99久久久久 | 久久好看| 久热久草在线 | 国产精品人成电影在线观看 | 成人一级在线观看 | 91人人视频在线观看 | 综合网天天 | 日韩精品在线免费播放 | 丁香六月婷婷开心婷婷网 | 中文字幕一区二区三区乱码在线 | 国产成人一二片 | 香蕉一区| 在线观看小视频 | 日日色综合 | 69av视频在线 | 成人av在线一区二区 | 日韩欧美精品在线 | 亚洲激情在线观看 | 中文字幕av影院 | 91在线视频在线观看 | 日韩中文在线播放 | 精品久久一二三区 | 久久99国产视频 | 99精品免费久久久久久久久 | 国产精品一区二区在线免费观看 | 成人免费在线网 | av888.com| 91av看片| 黄色小网站在线 | 亚洲精品自拍视频在线观看 | 最近中文字幕大全中文字幕免费 | 日韩国产欧美视频 | 五月天婷婷视频 | 成人中文字幕在线观看 | 特黄特黄的视频 | 天天射天天射 | 成人av影视 | 不卡的一区二区三区 | 日韩欧美精品一区二区三区经典 | 日本激情视频中文字幕 | 亚洲日本成人网 | 天天操天天干天天干 | 久草精品视频在线看网站免费 | 日韩区在线观看 | 中文字幕区 | 欧美日韩视频一区二区三区 | 一区二区三区免费在线 | 在线观看黄色国产 | 激情综合站 | 天天操夜夜拍 | 99精品视频在线观看免费 | 日韩a级免费视频 | www,黄视频| 欧美在线视频a | 精品国产色 | 一级一片免费看 | 国产精品久久三 | 亚洲精品免费在线观看视频 | 亚洲在线成人精品 | 日韩乱码在线 | 99久久精品日本一区二区免费 | 久久不卡国产精品一区二区 | 在线激情av电影 | 九九热在线免费观看 | 天天操天天干天天摸 | 国产成人久久av977小说 | 久久69av| 国产精品麻豆91 | 最近最新中文字幕视频 | 九九九九色| 欧美综合在线观看 | 日韩中文字幕在线不卡 | 干 操 插 | 久久综合婷婷国产二区高清 | 成人黄色片在线播放 | 久艹视频免费观看 | 黄色大片中国 | 欧美性大战 | 96久久 | 久久超碰99| 久久久国产日韩 | 美州a亚洲一视本频v色道 | 免费福利片 | 国产高清在线a视频大全 | 91色影院| 九月婷婷色| 国产一区二区在线视频观看 | 日韩精品久久久久久 | 亚洲日本在线视频观看 | 亚洲黄色在线观看 | 日日爽天天 | 国产理伦在线 | 在线欧美日韩 | 国产美女久久久 | 国产美女网 | 国产不卡视频 | 国产精品igao视频网入口 | 国产精品久久久毛片 | 国产免费作爱视频 | 99久久www| 婷婷久久五月天 | 国产精品系列在线观看 | 最新日本中文字幕 | 精品国产免费看 | 久久精品一区二区 | 欧美va天堂va视频va在线 | 尤物97国产精品久久精品国产 | 蜜桃传媒一区二区 | 天天添夜夜操 | 国内少妇自拍视频一区 | 天天av综合网 | 欧美精品日韩 | 亚洲精品视频观看 | 欧美精品乱码久久久久 | 中文字幕在线观看资源 | 黄色三级在线观看 | 色综合久久久网 | 久久久国产精品麻豆 | 精品国产美女在线 | 日韩最新在线 | 麻豆视频大全 | 午夜精品久久一牛影视 | 国产福利av在线 | 国产精品久久毛片 | 亚洲精品456在线播放乱码 | 国产网站av| 人人讲| 亚洲va天堂va欧美ⅴa在线 | 久久视频免费在线 | 麻豆国产露脸在线观看 | 99热精品国产一区二区在线观看 | 最近日本韩国中文字幕 | 天天操,夜夜操 | 丝袜美腿一区 | 亚洲成aⅴ人片久久青草影院 | 一级黄色在线免费观看 | 热热热热热色 | 又黄又爽又刺激的视频 | av在线观| 五月婷婷婷婷婷 | 免费看污网站 | 中文字幕影视 | 欧美日韩一区二区三区免费视频 | 国产成人精品一区二区三区福利 | 97精产国品一二三产区在线 | 午夜久久久精品 | 久久久国产精品成人免费 | 精品久久久久久亚洲综合网站 | av黄色国产| 91在线产啪 | 高清av中文在线字幕观看1 | av丝袜美腿 | 久久噜噜少妇网站 | 亚洲欧美日韩一区二区三区在线观看 | 黄色av电影一级片 | 日韩国产精品毛片 | 国产精品人人做人人爽人人添 | 麻豆91在线 | 九九热在线观看视频 | 日韩精品免费在线观看视频 | 国产福利在线免费观看 | 色综合久久久久 | 亚洲电影免费 | 免费av在线网站 | av888av.com| 日本最新中文字幕 | 亚洲国产日韩av | 69绿帽绿奴3pvideos | 国产精品自拍在线 | 国产亚洲精品美女 | 国产91精品高清一区二区三区 | 日韩欧美一区二区三区视频 | 日本一区二区三区视频在线播放 | 亚洲色图美腿丝袜 | 青青射| 日韩激情视频在线 | 国产伦理一区 | 久久精品成人热国产成 | 国产欧美日韩视频 | 不卡的av电影 | 国产尤物在线 | 午夜久久福利视频 | 亚洲va欧美va国产va黑人 | 888av| 97香蕉超级碰碰久久免费软件 | 91豆花在线观看 | 精品一区二区在线免费观看 | 一区中文字幕电影 | 黄色a在线观看 | 亚洲午夜精品电影 | 免费高清男女打扑克视频 | 一区二区三区四区免费视频 | 亚洲一区二区视频在线播放 | 91探花视频 | 在线看日韩av | 久草在线免费资源 | 国产一区二区在线观看免费 | 久久久久久久久久久网站 | 又爽又黄在线观看 | 日韩av电影中文字幕在线观看 | 一级α片免费看 | 亚洲精品视频大全 | 久久综合久色欧美综合狠狠 | 亚洲欧美视屏 | 美女网站视频免费都是黄 | 国内视频在线观看 | 日韩免费视频线观看 | 91桃花视频 | 97精品国产手机 | 在线 高清 中文字幕 | 日批在线看 | 久保带人| 国产久视频 | 精品视频123区在线观看 | 色播五月激情五月 | 日韩欧美精品一区二区 | 超碰日韩在线 | 91成人免费在线视频 | 在线中文字幕av观看 | 久久精品一二三 | 亚洲黄色一级电影 | 在线观看激情av | 婷婷五月情 | 亚洲高清久久久 | 综合久久久久 | 欧美在线你懂的 | 亚洲视频免费在线观看 | 国产在线欧美在线 | 麻豆成人小视频 | 久精品视频 | 99久久er热在这里只有精品66 | 中文字幕在线一二 | 99精品国产福利在线观看免费 | 色人久久| 免费一级特黄毛大片 | 亚洲精品国产区 | 高清国产午夜精品久久久久久 | 夜夜爱av | 99视 | 免费看色的网站 | av解说在线 | 波多野结衣视频一区二区三区 | 成人app在线免费观看 | 久久在现视频 | 中文字幕制服丝袜av久久 | 日韩免费一级a毛片在线播放一级 | 国产一级片免费观看 | 99久久99久久综合 | 天天天操天天天干 | 偷拍久久久 | 综合网在线视频 | 天天操天天摸天天爽 | 欧美性免费 | 亚洲综合小说电影qvod | 蜜臀精品久久久久久蜜臀 | 久久久久久福利 | 一本色道久久精品 | 久久亚洲视频 | 五月婷亚洲 | 欧美精品一区在线发布 | 国产精品永久免费观看 | 天天射成人 | 97免费公开视频 | 99久久精品免费看国产一区二区三区 | 亚洲欧美国产精品 | 久久精品这里都是精品 | 偷拍福利视频一区二区三区 | 不卡日韩av | 91在线小视频 | 国产精品久久久久aaaa | 能在线看的av | www.天天综合 | 婷婷久久一区二区三区 | 国产专区欧美专区 | 中文字幕有码在线观看 | 国产 av 日韩 | 精品伊人久久久 | 午夜精品久久久久久久久久 | 欧美精品生活片 | 国产日韩视频在线播放 | 五月婷婷在线综合 | 久久精品视频在线免费观看 | 久久爱资源网 | 探花视频在线观看免费 | 日本在线观看黄色 | 黄色av高清 | 成人免费xxx在线观看 | 天天激情站 | 免费看一级黄色大全 | av大片网址 | 日韩理论 | 久草视频播放 | 欧美日韩国内在线 | 成人免费看片网址 | 婷婷丁香社区 | 97在线观看视频国产 | 久精品视频免费观看2 | 996久久国产精品线观看 | 欧洲色吧 | 亚洲最新精品 | 欧美一级片免费在线观看 | 久草久草久草久草 | 亚洲激情在线观看 | 亚洲一区美女视频在线观看免费 | 人人狠狠综合久久亚洲婷 | 91视频久久久久久 | 免费在线看v | 欧美成人精品三级在线观看播放 | 亚洲成av片人久久久 | 99视频在线观看一区三区 | 天天操天天舔天天爽 | 免费在线电影网址大全 | 96久久久 | 精品在线观看免费 | 免费看国产曰批40分钟 | 黄色软件大全网站 | 91亚洲在线 | 久久久久高清毛片一级 | 欧美另类人妖 | 九九视频免费在线观看 | 国产亚洲视频中文字幕视频 | 麻豆综合网 | 国产系列精品av | 欧美一级特黄高清视频 | 九九九热精品免费视频观看网站 | 欧美另类高清 videos | 九九视频在线播放 | 久久艹国产视频 | 中文字幕高清av | 色欧美88888久久久久久影院 | 福利视频一二区 | 又黄又网站 | 欧美在线1区 | 亚洲h在线播放在线观看h | 国产在线色视频 | 日韩中文字幕亚洲一区二区va在线 | 少妇精品久久久一区二区免费 | 国产精久久久久久妇女av | 91丨porny丨九色 | 久久人人爽人人爽人人片av软件 | 中文字幕频道 | 午夜久久久久久久 | 国产成人在线观看 | 国产精品第52页 | 国产一区播放 | 欧洲精品亚洲精品 | 久久久www成人免费毛片麻豆 | 久久综合九色九九 | 超碰免费久久 | 国产成人免费观看久久久 | 最新国产一区二区三区 | 成人免费观看大片 | 色全色在线资源网 | 天天综合网在线观看 | 91精品天码美女少妇 | 国产精品久久久久久久久久久免费看 | 国产午夜精品一区二区三区在线观看 | 亚洲激情小视频 | 高清国产午夜精品久久久久久 | 91秒拍国产福利一区 | 国产伦理一区二区三区 | av黄色成人 | 精品久久久久久国产91 | 天天天色综合 | 91麻豆免费看 | 久久国产露脸精品国产 | 在线一区电影 | 一区中文字幕在线观看 | 91女人18片女毛片60分钟 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 国产热re99久久6国产精品 | 欧美久久久一区二区三区 | 久久久综合精品 | 日韩专区在线 | www.国产在线 | 日韩欧美一区二区三区在线观看 | 日韩电影中文字幕在线观看 | 欧美日韩高清在线 | 日韩av一区二区在线播放 | 九九免费在线看完整版 | 中文在线免费观看 | 国产在线免费观看 | 免费在线观看av片 | 美女免费视频观看网站 | 国产精品高清在线 | 亚洲资源在线观看 | 色婷婷五 | 久久免费av| 亚洲视频精选 | 又长又大又黑又粗欧美 | 色永久免费视频 | 免费av网址大全 | 狠狠狠色丁香婷婷综合激情 | 亚洲美女精品 | 婷婷激情网站 | 色小说在线 | 精品一区二区久久久久久久网站 | 91理论片午午伦夜理片久久 | 97精品伊人| 国产精品av久久久久久无 | 91女子私密保健养生少妇 | 欧美日产在线观看 | 精品少妇一区二区三区在线 | 麻豆视频在线 | 亚洲精品午夜久久久 | 色橹橹欧美在线观看视频高清 | 久久午夜免费视频 | 特级a毛片 | 久久国产露脸精品国产 | 国产精品97| 久久国内精品视频 | 日韩黄色在线电影 | 久久视频精品在线 | 久久视频 | 五月婷在线视频 | 国产在线精品福利 | 久久免费精品视频 | 国产黄色大片 | 天天舔夜夜操 | 国产中文字幕在线看 | 在线99| 97看片网| 久久久久麻豆v国产 | 99色在线 | 国产亚洲精品女人久久久久久 | www.少妇| 久久综合偷偷噜噜噜色 | av久久久 | 国产精品v欧美精品 | 久草久草在线观看 | 久久久久综合精品福利啪啪 | 超碰在线人人 | 伊人黄色网 | 91丨九色丨蝌蚪丨老版 | 91亚洲精品久久久中文字幕 | 欧美色图88 | 成人国产综合 | 国产小视频91 | 国产成人av免费在线观看 | 天天操天天射天天爽 | 国产精品不卡在线播放 | 99视频黄 | 久久69精品久久久久久久电影好 | 视频在线一区二区三区 | 国产精品美女久久久久久久网站 | 日韩精品三区四区 | 免费亚洲片 | 国产高清中文字幕 | 免费福利小视频 | 亚洲成人黄色在线观看 | 国产精品一区二区三区免费看 | 在线观看色网站 | 免费久久久久久久 | 91精品人成在线观看 | 国产亚洲精品久久久久久移动网络 | 国产a高清| 97日日碰人人模人人澡分享吧 | 久久久国产一区二区三区 | 五月婷社区 | 激情五月播播久久久精品 | 成人在线观看免费视频 | 婷婷在线精品视频 | 三级免费黄色 | 免费污片| 欧美视频国产视频 | 成年人在线看片 | 国产精品v欧美精品v日韩 | 免费91在线观看 | 国产视频69 | 精品一区二区三区四区在线 | 中文字幕在线国产 | 粉嫩av一区二区三区入口 | 中文字幕欧美日韩va免费视频 | 国产专区精品视频 | 国产一区二区三精品久久久无广告 | 国产精品毛片一区二区三区 | 丁香婷婷久久 | 99久久精品免费看国产四区 | 国产在线观看一区 | 日韩美在线 | 国产午夜三级一二三区 | 91亚洲精品久久久久图片蜜桃 | 国产又粗又猛又爽又黄的视频先 | 午夜av片| 天天·日日日干 | 国产精品一区二区 91 | 久久精品成人欧美大片古装 | 天天拍天天操 | www.神马久久| 在线观看免费视频你懂的 | 日韩免费看视频 | 我要色综合天天 | 国产成人精品久 | 欧美 日韩 国产 成人 在线 | 久久精品国产第一区二区三区 | 五月婷婷爱 | 国产永久免费高清在线观看视频 | 99视频一区二区 | 2019中文最近的2019中文在线 | 欧美一级大片在线观看 | 久久美女高清视频 | 成人免费视频视频在线观看 免费 | 综合五月 | 毛片网站在线 | 成年人在线看视频 | 国产黑丝袜在线 | 国产精品亚洲综合久久 | 色综合天天色综合 | 久免费 | 香蕉一区| 精品美女久久久久久免费 | 国产a精品 | 亚洲v精品 | 国产黄色精品在线观看 | 久保带人 | 黄色免费网 | 在线视频99 | 九九九热精品免费视频观看网站 | 又黄又爽又色无遮挡免费 | 国产九色视频在线观看 | 国产精品久久99精品毛片三a | 福利视频网站 | 婷婷丁香色 | 欧美一区二区三区在线视频观看 | 亚洲国产播放 | 欧美日韩网址 | 日韩在线观看一区二区 | 夜夜澡人模人人添人人看 | 91av在线免费看| 狠狠操欧美 | 亚洲精品欧美成人 | 337p日本欧洲亚洲大胆裸体艺术 | 久久久久久久久久久影院 | 国产精品av在线 | 亚洲人毛片 | 国产成人一区二区三区免费看 | 成人在线观看免费视频 | 亚洲一区二区高潮无套美女 | 久久成人在线视频 | 免费日韩电影 | 天天做天天爽 | 91精品国产三级a在线观看 | 亚洲精品成人 | 欧美日韩精品综合 | 国产视频 亚洲精品 | 久久精品在线免费观看 | 国产精品免费在线观看视频 | 欧美精品免费在线 | 日本乱码在线 | 久99久精品 | 天天操夜夜爱 | 日韩在线短视频 | 成人黄色在线电影 | 黄色av电影网 | 99久久精品国产一区 | 免费观看一级成人毛片 | 精品久久久久久久久久久久久久久久久久 | 91porny九色91啦中文 | 69视频永久免费观看 | 人人爽人人爽人人片av免 | 一级α片免费看 | 亚洲视频六区 | 日韩高清免费无专码区 | 国产一二三四在线视频 | 中国精品少妇 | 日韩中文在线电影 | 激情亚洲综合在线 | 久色小说 | 亚洲做受高潮欧美裸体 | 免费观看www7722午夜电影 | 最近日本字幕mv免费观看在线 | 成人免费视频网 | 国产成人精品久久久久蜜臀 | 国产专区一| 最新日韩电影 | 久久久久久久久电影 | 国产免费av一区二区三区 | av品善网| 激情综合一区 | 天天干夜夜操视频 | 手机在线观看国产精品 | 在线观看中文 | 国产高清视频在线免费观看 | 国产精品成人一区二区三区吃奶 | 在线成人观看 | 丁香婷婷激情国产高清秒播 | 7777精品伊人久久久大香线蕉 | 亚洲精品久久在线 | 91精品办公室少妇高潮对白 | 最近2019好看的中文字幕免费 | 中文字幕一区二区三区四区在线视频 | 久久色在线观看 | 99视频精品全部免费 在线 | 国产小视频在线观看免费 | 天堂va在线高清一区 | 丁香六月欧美 | 黄色av一级片 | 在线观看一区二区精品 | 香蕉视频4aa| 国产精品久久久久久久7电影 | 免费日韩高清 | 一区二区丝袜 | 91看片成人 | 男女激情网址 | 日韩精品免费专区 | 久久人人爽人人爽人人 | 中文久草 | 国产精品日韩在线观看 | www.久艹| 在线视频手机国产 | 天天干天天干天天干天天干天天干天天干 | 国产视频色 | 中文字幕文字幕一区二区 | 精品久久网 | 97超碰在| 国产欧美日韩精品一区二区免费 | 色欲综合视频天天天 | 中文av网 | 手机在线观看国产精品 | 亚洲午夜精品福利 | 色婷婷在线视频 | 日韩91在线 | 黄色特一级| 欧美亚洲另类在线视频 | 伊人国产视频 | 免费看国产黄色 | 美州a亚洲一视本频v色道 | 天天射天天干天天插 | 精品国产免费人成在线观看 | 色偷偷av男人天堂 | 精品国产一区二区三区日日嗨 | 91在线视频播放 | 日日久视频 | av片中文 | 五月开心六月伊人色婷婷 | 久久久久久久久网站 | 国产精品国产三级国产专区53 | 高清av网站 | 夜夜操天天摸 | 精品国产中文字幕 | 正在播放 国产精品 | 久久av网 | 综合久久精品 | 日韩欧美第二页 | 国产亚洲精品久久久久5区 成人h电影在线观看 | av免费观看网站 | 日韩大片在线观看 | 一级黄色电影网站 | 四虎影院在线观看av | 精品超碰 | 久久婷婷激情 | 久久国产视屏 | 91成年人在线观看 | 五月天中文在线 | 久久天堂精品视频 | 福利视频精品 | 国产在线a视频 | 伊人成人久久 | 伊甸园永久入口www 99热 精品在线 | 国产一区二区精品在线 | 五月天丁香亚洲 | 日韩精品久久久久久久电影99爱 | 久久免费视频国产 | 欧美一性一交一乱 | 欧美在线视频a | 国产精品大全 | 中文字幕频道 | 免费热情视频 | 久久精品区| 中文字幕免费在线 | 久久综合色影院 | 亚洲 综合 精品 | 一区二区三区手机在线观看 | 国产精品igao视频网入口 | 天海冀一区二区三区 | 午夜视频在线观看一区二区 | 日日综合| 亚洲精品成人网 | www.五月天婷婷.com | 最新av电影网址 | 国产第一二区 | 在线观看视频福利 | 亚洲 中文 在线 精品 | 欧美一级日韩免费不卡 | 日日干美女 | 国产97av| 丁香婷婷基地 | 92精品国产成人观看免费 | 91九色pron| 日韩欧美视频免费在线观看 | 欧美在线1 | 国产午夜在线观看 | 久久久精品一区二区 | 免费观看国产视频 | 麻豆va一区二区三区久久浪 | 91精品国产综合久久婷婷香蕉 | 亚洲视频电影在线 | 热久久精品在线 | 夜夜视频 | 在线视频免费观看 | 久久尤物电影视频在线观看 | 国产成年免费视频 | 一级成人在线 | 国产一区成人 | 国产精品9999久久久久仙踪林 | 91久久国产露脸精品国产闺蜜 | 波多野结衣视频一区二区 | 国产精品入口66mio女同 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 成人av电影免费在线播放 | 久草视频看看 | 人人看人人做人人澡 | 四虎影视8848dvd | 精品久久久久久久久久久久久久久久 | 天天天插 | av成人亚洲 | 麻豆91在线看 | 成在线播放 | 国产黄色大片免费看 | 九九热视频在线 | 在线精品在线 | 中文字幕在线看视频国产中文版 | 欧美久久久久久久 | 亚洲爱爱视频 | 亚洲成av人影片在线观看 | 69国产盗摄一区二区三区五区 | 欧美一级专区免费大片 | 在线黄av | 美女网站在线观看 | 国产伦精品一区二区三区四区视频 | 久久亚洲私人国产精品va | 欧美日韩免费在线观看视频 | 精品视频国产 | 永久免费精品视频 | 2024av在线播放 | 久久亚洲人| 99久久精品电影 | 国产一区二区不卡视频 | 极品国产91在线网站 | 色小说av | 开心丁香婷婷深爱五月 | 超碰人人在线观看 | 处女av在线 | 日本99久久| 久久久久久久影视 | 色午夜影院 | 精品主播网红福利资源观看 | 国产精品黄网站在线观看 | 国产精品成人在线 | 欧美激情精品 | 日韩高清一 | 天天草天天插 | 国产亚洲在线视频 | 色网站在线免费 | 欧美一区二区三区在线看 | 欧美极品xxx | 久久tv| av动态图片 | 天天干一干 | 日批网站免费观看 | 精品亚洲免a| 激情五月色播五月 | 成人在线观看免费 | 欧美一级久久久久 | 黄色三级av | 欧美亚洲成人xxx | 在线视频成人 | 91久久偷偷做嫩草影院 | 日本成人免费在线观看 | 成人久久久电影 | 欧美了一区在线观看 | 国产精品久久久久久久午夜片 | 国产成人精品久久久久 | 国产 字幕 制服 中文 在线 | 日本中文在线 | 黄色片亚洲| www.久草.com| 国产精品久久9 | 韩国av免费观看 | 久久a免费视频 | 免费在线观看不卡av | 亚洲第五色综合网 | 99色在线播放 | 久久精品精品 | 免费看黄网站在线 | 日日干夜夜操视频 | 免费男女羞羞的视频网站中文字幕 | av电影在线免费 | 中文字幕资源在线 | 国产精品一区二 | 亚洲精品系列 | 亚洲欧美日韩精品一区二区 |