青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

浪跡天涯

唯有努力...
努力....再努力...

人機猜數游戲

請人想一個四位的整數,計算機來猜,人給計算機提示信息,最終看計算機用幾次猜出一個人“想”的數。請編程實現。

問題分析
解決這類問題時,計算機的思考過程不可能象人一樣具完備的推理能力,關鍵在于要將推理和判斷的過程變成一種機械的過程,找出相應的規則,否則計算機難以完成推理工作。
基于對問題的分析和理解,將問題進行簡化,求解分為兩個步聚來完成:首先確定四位數字的組成,然后再確定四位數字的排列順序。可以列出如下規則:
1)產生四位數字的全部排列產生四位數字的全部排列。
2)生成隨機數,根據,根據人輸入的正確數字及正確位置的數目,進行刷選。
3)再剩下的結果中,生成隨機數,重復步驟2,直至找到。

GetNextGuess()函數算法不知該如何理解?
我覺得這個函數算法不好,沒有充分利用先前的猜數以及結果進行下一次的猜數。

程序代碼:
#include <iostream>
#include <time.h>
#include <string>
#include <list>
#include <limits>

using namespace std;
list<string> numList;

void   Initialize();
string RanddomNum();
string GetNextGuess();
int    CountN(const string &guess, const string &str);
int    CountP(const string &guess, const string &str);


int main()
{
 Initialize();   // 初始化
 string guess = RanddomNum(); // 第1回合隨機猜數
 int n, p;    // 分別表示有幾個數字猜對,有幾個數字位置也對
 
 while (1)
 {
  cout << guess << endl;
  cin >> n >> p;
  if (n == 4 && p == 4) // 猜中
   break;
  list<string>::iterator it;
  for (it = numList.begin();it != numList.end();)
  {
   if (CountN(guess, *it) != n) // 如果沒有n個數字對
   {
    it = numList.erase(it);  // 不可能是被猜數,篩掉
    continue;
   }
   if (CountP(guess, *it) != p) // 如果沒有p個數字位置對
   {
    it = numList.erase(it);  // 不可能是被猜數,篩掉
    continue;
   }
   ++it;
  }
  if (numList.empty()) // 沒有候選數了,人欺騙計算機
  {
   cout << 0 << endl;
   break;
  }
  guess = GetNextGuess();
 }
 return 0;
}

void Initialize()
{
 char buf[5] = {0};
 for (int i = '1'; i <= '9'; i++)
  for (int j = '0'; j <= '9'; j++)
   for (int k = '0'; k <= '9'; k++)
    for (int l = '0'; l <= '9'; l++)
    {
     buf[0] = i;
     buf[1] = j;
     buf[2] = k;
     buf[3] = l;
     numList.push_back(buf);
    }
}

string RanddomNum()
{
 srand(time(NULL));
 int i = rand() % 9000 + 1000;
 char buf[5] = {0};
 sprintf(buf, "%d", i);
 return buf;
}

int CountN(const string &guess, const string &num)
{
 string s = num;  // 復制num,用于下面避免重復匹配的操作
 int count = 0;
 for (int i = 0; i < 4; i++) // 對guess中每一個數字
 {
  string::size_type pos = s.find(guess[i]);
  if (pos != string::npos)
  {
   count++;
   s[pos] = 'x';  // 為避免重復匹配,將它替換為字符’x’
  }
 }
 return count;
}


int CountP(const string &guess, const string &str)
{
 int count = 0;
 for (int i = 0; i < 4; i++)
  count += (guess[i] == str[i]);
 return count;
}

string GetNextGuess()
{
 int min = numeric_limits<int>::max();
 string guess;   // 猜這個數
 list<string>::iterator it,it2;
 for (it = numList.begin();it != numList.end(); ++it)
 {
  int a[5][5] = {0};
  for (it2 = numList.begin();it2 != numList.end(); ++it2)
  {
   int x = CountN(*it, *it2);
   if (x == 0)
    a[0][0]++;    // 如果n=0,p一定=0
   else
    a[x][CountP(*it, *it2)]++;
  }
  int sum = 0;
  for (int i = 0; i < 5; i++)
   for (int j = 0; j <=i; j++) // 位置對的數字個數不會超過猜對的數字個數
    sum += a[i][j] * a[i][j];
  if (sum < min)
  {
   sum = min;
   guess = *it;
  }
 }
 return guess;
}

posted on 2008-01-04 09:22 浪跡天涯 閱讀(756) 評論(0)  編輯 收藏 引用 所屬分類: C++

<2008年1月>
303112345
6789101112
13141516171819
20212223242526
272829303112
3456789

導航

統計

常用鏈接

留言簿(22)

隨筆分類(30)

隨筆檔案(29)

文章分類

搜索

積分與排名

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美性猛交一区二区三区精品| 久久在线播放| 国产欧美一区二区白浆黑人| 欧美日韩视频不卡| 免费一区视频| 亚洲自拍电影| 久久电影一区| 久久综合影视| 欧美午夜不卡影院在线观看完整版免费| 欧美精品一区在线发布| 国产精品久久久久久久久动漫| 国产精品分类| 一区二区三区中文在线观看 | 激情久久久久| 亚洲精品在线免费观看视频| 亚洲手机成人高清视频| 欧美一区二区三区四区在线观看地址 | 日韩天堂在线视频| 亚洲尤物视频网| 久久久久久国产精品mv| 欧美大胆人体视频| 国产精品女人毛片| 最近看过的日韩成人| 亚洲欧美日韩在线| 蜜桃久久av| 亚洲一区二区三区激情| 蜜月aⅴ免费一区二区三区| 欧美性淫爽ww久久久久无| 黄色精品一二区| 一区二区三区免费观看| 农村妇女精品| 亚洲女同在线| 欧美日韩一二三四五区| 黄色成人av在线| 亚洲欧美三级伦理| 欧美激情乱人伦| 久久精品日韩欧美| 国产精品久久久久久模特 | 欧美有码在线观看视频| 欧美激情中文字幕一区二区| 亚洲欧美视频| 欧美日韩精品在线观看| 亚洲国产精品第一区二区三区| 午夜综合激情| 亚洲神马久久| 欧美日韩专区| 日韩午夜免费视频| 欧美福利网址| 久久精品综合一区| 国产欧美另类| 欧美尤物一区| 亚洲女女女同性video| 欧美色欧美亚洲另类二区| 久久中文久久字幕| 亚洲一区免费视频| 欧美日韩激情小视频| 亚洲高清免费| 久久综合伊人77777尤物| 亚洲免费影视| 国产精品视频免费观看| 午夜精品视频在线| 亚洲视频久久| 国产精品久久久久久久电影| 亚洲最新色图| 99热这里只有成人精品国产| 欧美日韩视频不卡| 亚洲在线视频| 亚洲欧美激情在线视频| 国产欧美日韩视频| 久久久久一本一区二区青青蜜月| 午夜精品福利在线| 国产在线视频欧美| 你懂的国产精品永久在线| 久久久久久999| 亚洲第一网站免费视频| 欧美国产视频一区二区| 欧美日韩精品不卡| 亚洲欧美第一页| 欧美一区二区福利在线| 一区二区三区在线看| 亚洲第一页中文字幕| 欧美777四色影视在线| 99视频一区二区三区| 亚洲视频二区| 国内精品久久久久伊人av| 欧美成人免费va影院高清| 欧美精品亚洲精品| 香港成人在线视频| 久久精品99国产精品酒店日本| 亚洲高清视频在线| av成人福利| 国产原创一区二区| 91久久夜色精品国产九色| 国产精品国产一区二区| 久久亚洲综合色| 欧美日产一区二区三区在线观看| 欧美一区日本一区韩国一区| 麻豆成人综合网| 午夜精品福利视频| 久久全国免费视频| 亚洲欧美日韩中文视频| 久久这里有精品视频| 亚洲免费一在线| 蜜桃av噜噜一区二区三区| 亚洲欧美文学| 欧美成人午夜视频| 久久精品女人| 欧美四级在线观看| 亚洲高清资源| 激情六月婷婷久久| 亚洲一区二区黄| 99热精品在线观看| 久久精品视频导航| 亚洲天堂免费观看| 免费成人av| 久久久噜噜噜久噜久久| 在线观看欧美日韩国产| 久久精品人人做人人爽电影蜜月| 99视频一区二区三区| 久久久蜜桃精品| 欧美一区二区三区四区高清| 欧美精品一二三| 欧美成年人视频| 国产一区二区在线观看免费| 一区二区日韩精品| 亚洲精品永久免费| 快she精品国产999| 久久伊人一区二区| 国产一区二区三区在线观看精品| 在线综合视频| 在线综合+亚洲+欧美中文字幕| 欧美sm重口味系列视频在线观看| 久久久久久香蕉网| 国际精品欧美精品| 欧美一区二区三区视频在线观看| 亚洲欧美三级伦理| 国产精品久久一级| 亚洲一区二区三区四区在线观看 | 亚洲日韩成人| 亚洲精品国产精品国自产观看 | 亚洲精品一区二区三区99| 最新国产拍偷乱拍精品| 免费h精品视频在线播放| 麻豆精品国产91久久久久久| 韩国av一区二区三区在线观看| 亚洲欧美中文另类| 久久99在线观看| 国语自产偷拍精品视频偷| 久久精品一区二区| 亚洲国产成人91精品| 99av国产精品欲麻豆| 欧美金8天国| 亚洲人成人一区二区三区| 一区二区三区色| 国产精品视频99| 欧美一区二区性| 欧美本精品男人aⅴ天堂| 亚洲伦理自拍| 国产精品久久久久久久久久直播| 午夜精彩国产免费不卡不顿大片| 久久久久99| 亚洲国产成人久久| 欧美日韩视频不卡| 欧美影院视频| 亚洲高清不卡| 亚洲欧美国产高清| 国内精品视频在线观看| 欧美激情aaaa| 亚洲综合视频1区| 欧美激情1区2区3区| 亚洲一二三四区| 国内精品视频666| 欧美精品国产精品| 欧美一区二区三区喷汁尤物| 欧美成人精品影院| 亚洲国产小视频在线观看| 欧美日韩在线一区二区| 羞羞漫画18久久大片| 国产精品一卡二卡| 欧美国产综合一区二区| 久久精品欧美日韩| 亚洲国产一区二区视频| 欧美精品一区二区在线观看| 亚洲天堂av图片| 欧美高清在线一区| 亚洲一二三级电影| 亚洲国产精品福利| 国产精品色一区二区三区| 久久精品免费| 亚洲美女诱惑| 欧美成人午夜77777| 性xx色xx综合久久久xx| 亚洲激情精品| 国产中文一区| 国产精品久久久久国产精品日日| 欧美专区亚洲专区| 亚洲性人人天天夜夜摸| 欧美大胆人体视频| 久久久久在线| 久久精品动漫|