數獨游戲的設計與開發(fā)【畢業(yè)論文】 (2)_第1頁
已閱讀1頁,還剩16頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、<p><b>  本科畢業(yè)論文</b></p><p><b> ?。?0 屆)</b></p><p>  數獨游戲的設計與開發(fā)</p><p><b>  摘要</b></p><p>  本文介紹了利用C++語言編寫數獨游戲的方法。游戲的開發(fā)設計使用了vs2

2、010作為開發(fā)工具,根據數獨游戲特有的規(guī)則特點對游戲進行設計。并且游戲在開發(fā)的過程中使用了微軟的MFC開源框架,在數獨游戲的界面上做了一定的處理。本文首先對游戲進行了簡單的介紹,對游戲的計算機實現進行分析。最后通過部分游戲截圖和數據表格來介紹了游戲的開發(fā)設計過程和游戲的基本操作。并根據軟件工程的方法,從需求分析、概要設計、詳細設計、編碼實現等方面闡述了游戲的開發(fā)流程,并通過游戲界面的截圖、數據表格等體現了我的設計思路。</p>

3、;<p>  關鍵字:數獨 C++ MFC 畢業(yè)設計</p><p><b>  TAbstract</b></p><p>  This paper describes the use of C + + method number written language alone game. Game development and design usin

4、g vs2010 as a development tool, according to the Sudoku rules specific to the characteristics of the game design. And the game uses Microsoft's MFC source framework development process, in Sudoku interface to do some

5、 processing. This paper first gives a brief introduction to the game, the game's computer-implemented analysis. Finally, some games screenshots and data tables to introduc</p><p>  Keywords: Sudoku C++

6、 MFC graduation</p><p><b>  目錄</b></p><p>  1 引言.................................................................1</p><p>  1.1 簡介......................................

7、......................1</p><p>  1.2 數獨的起源.....................................................1</p><p>  1.3 數獨的發(fā)展.....................................................1</p><p>  2

8、開發(fā)環(huán)境及開發(fā)工具...................................................2</p><p>  2.1 C++語言簡介....................................................2</p><p>  2.2 MFC語言簡介......................................

9、..............2</p><p>  3.系統(tǒng)的需求分析.......................................................2</p><p>  3.1現行系統(tǒng)概況描述...............................................,2</p><p>  3.2需求分析....

10、....................................................2</p><p>  系統(tǒng)開發(fā)可行性分析...................................................2</p><p>  系統(tǒng)分析........................................................

11、.....2</p><p>  6.系統(tǒng)設計.............................................................3</p><p>  6.1設計思路........................................................3</p><p>  6.2系統(tǒng)主要類設計...

12、...............................................3</p><p>  6.2.1 GamePad類.................................................3</p><p>  6.2.2 SudokuDlg類..............................................

13、.4</p><p>  6.2.3 Sudokugame類..............................................5</p><p>  7.系統(tǒng)主要技術特色.....................................................11</p><p>  8.結論................

14、.................................................11</p><p>  9.參考文獻.............................................................12</p><p>  10.致謝.................................................

15、...............12</p><p><b>  1.引言</b></p><p><b>  1.1簡介</b></p><p>  數獨游戲是一種源自18世紀末的瑞士,后在美國發(fā)展、并在日本得以發(fā)揚光大的數學智力拼圖游戲。拼圖是九宮格(即3格寬×3格高)的正方形狀,每一格又細分為一個九宮格。在每

16、一個小九宮格中,分別填上1至9的數字,讓整個大九宮格每一列、每一行的數字都不重復。 數獨的玩法邏輯簡單,數字排列方式千變萬化。不少教育者認為數獨是鍛煉腦筋的好方法。</p><p><b>  圖1.1</b></p><p><b>  1.2數獨的起源</b></p><p>  數獨前身為“九宮格”,最早起源于中國。

17、數千年前,我們的祖先就發(fā)明了洛書,其特點較之現在的數獨更為復雜,要求縱向、橫向、斜向上的三個數字之和等于15,而非簡單的九個數字不能重復。儒家典籍《易經》中的“九宮圖”也源于此,故稱“洛書九宮圖”。而“九宮”之名也因《易經》在中華文化發(fā)展史上的重要地位而保存、沿用至今。</p><p>  1783年,瑞士數學家萊昂哈德·歐拉發(fā)明了一種當時稱作“拉丁方塊”(Latin Square)的游戲,這個游戲是一

18、個n×n的數字方陣,每一行和每一列都是由不重復的n個數字或者字母組成的。</p><p>  19世紀70年代,美國的一家數學邏輯游戲雜志《戴爾鉛筆字謎和詞語游戲》(Dell Puzzle Mαgαzines)開始刊登現在稱為“數獨”的這種游戲,當時人們稱之為“數字拼圖”(Number Place),在這個時候,9×9的81格數字游戲才開始成型。</p><p><

19、;b>  1.3數獨的發(fā)展</b></p><p>  1984年4月,在日本游戲雜志《字謎通訊Nikoil》(《パズル通信ニコリ》)上出現了“數獨”游戲,提出了“獨立的數字”的概念,意思就是“這個數字只能出現一次”或者“這個數字必須是惟一的”,并將這個游戲命名為“數獨”(sudoku)。一位前任香港高等法院的新西蘭籍法官高樂德(Wayne Gould)在1997年3月到日本東京旅游時,無意中

20、發(fā)現了。他首先在英國的《泰晤士報》上發(fā)表,不久其他報紙也發(fā)表,很快便風靡全英國,之后他用了6年時間編寫了電腦程式,并將它放在網站上,使這個游戲很快在全世界流行。從此,這個游戲開始風靡全球。后來更因數獨的流行衍生了許多類似的數學智力拼圖游戲,例如:數和、殺手數獨。</p><p><b>  2.開發(fā)工具及環(huán)境</b></p><p>  2.1 C++語言簡介<

21、/p><p>  C++語言是一種優(yōu)秀的面向對象程序設計語言,它在C語言的基礎上發(fā)展而來,但它比C語言更容易為人們學習和掌握。</p><p>  C++以其獨特的語言機制在計算機科學的各個領域中得到了廣泛的應用。面向對象的設計思想是在原來結構化程序設計方法基礎上的一個質的飛躍,C++完美地體現了面向對象的各種特性。</p><p><b>  2.2 MFC

22、簡介</b></p><p>  MFC,微軟基礎類(Microsoft Foundation Classes),實際上是微軟提供的,用于在C++環(huán)境下編寫應用程序的一個框架和引擎。MFC是Win API與C++的結合,API,即微軟提供的WinDOS下應用程序的編程語言接口,是一種軟件編程的規(guī)范,但不是一種程序開發(fā)語言本身,可以允許用戶使用各種各樣的第三方的編程語言來進行對WinDOS下應用程序的開

23、發(fā),使這些被開發(fā)出來的應用程序能在WinDOS下運行。</p><p><b>  3.系統(tǒng)需求分析</b></p><p>  3.1現行系統(tǒng)概況描述</p><p>  同類似的填字游戲不同,數獨受歡迎的原因之一是它既不需要豐富的百科知識,也不要掌握大量的詞匯,這使其能迅速為孩子和初學者所接受。根據游戲開始時的方格中已有的數字和位置,數獨難

24、易程度不同,有些復雜的甚至令數學家也不能完成。現在在各個系統(tǒng)平臺上都有數獨游戲的開發(fā),且用戶十分龐大</p><p><b>  3.2需求分析</b></p><p>  “數獨”,即“獨立的數字”的簡稱,游戲在一個9*9的方格中,有81個小方格組成,然后又分成9個大塊,每塊由3*3組成,就是九宮格,大九宮格里邊再嵌套9個小的九宮格,游戲開始前會有一些格子上寫好了數

25、字,你需要在剩下的格子里面填寫數字,直到把所有的鴿子填滿,并且要求最后任何一行或者一列或者一個小九宮格中都不存在相同的數字。</p><p><b>  系統(tǒng)開發(fā)可行性分析</b></p><p>  據著名的動游戲開發(fā)商Astraware Ltd.預計,移動數獨游戲的版本多達幾十種,Palm和Windows Mobile設備版本的數獨游戲就各有20種左右。Sudok

26、umo推出的移動數獨游戲,能夠下載到大多數手機中。這家位于英國的游戲軟件公司表示,已經在全球賣出了7500套數獨游戲,而且來自用戶的興趣還在增加。因此,一個好的數獨游戲的開發(fā),可以吸引很多潛在的玩家。</p><p><b>  5.系統(tǒng)分析</b></p><p>  利用C++語言的面向對象特性,把生產游戲數據的程序封裝成一個類,在玩游戲時,只要根據數獨游戲的邏輯

27、性來編寫,先得到一個完整的數獨,然后根據難度需要,隨機的挖一些空格出來。便可以得到唯一解的數獨。</p><p>  終盤數量數獨中的數字排列千變萬化,那么究竟有多少種終盤的數字組合呢?共有6,670,903,752,021,072,936,960(約有6.67×10的21次方)種組合,2005年由Bertram Felgenhauer和Frazer Jarvis計算出該數字,并將計算方法發(fā)布在他們網站

28、上,如果將等價終盤(如旋轉、翻轉、行行對換,數字對換等變形)不計算,則有5,472,730,538個組合。數獨終盤的組合數量都如此驚人,那么數獨題目數量就更加不計其數了,因為每個數獨終盤又可以制作出無數道合格的數獨題目。 按照這個數量,如果我們將一個[1,2,3,4,5,6,7,8,9]的數組隨機化,然后將其作為一行數據添加到一個二維數組中去,該行能滿足數獨終盤規(guī)則的概率是很大的。 基于這個假設(假設的有效性會在文章后面驗證),我

29、的算法思想如下: </p><p>  寫一個方法用于獲取一個由1到9九個數隨機排列的一維數組。</p><p>  將獲取到的1到9的隨機數的一維數組放入九宮格中,每一個隨機數的列坐標循環(huán)采用1到9,行坐標使用1到9的隨機數,從而使步驟一中產生的隨機數隨機分布在九宮格中每一列中。</p><p>  循環(huán)尋找出當前九宮格中所有空白格中的右下角的一個空格。</

30、p><p>  寫一個算法找出某一個單元格中可以填入的數字的數組。</p><p>  在所有空白格中的最右下角的空白格中填入可能存在的數字,以此數據為新的游戲數據,接著循環(huán)尋找當前數據中空白格中的最右下角的空白格,填入當前空白格中可能存在的內容。</p><p>  遞歸尋找,若最后每一個空白格中都有可以填入的數字,則游戲終盤生產成功,否則往回遞歸,填入可能存在數字數

31、組中的第二個數組,循環(huán)遞歸,若仍然沒有終盤生產,則生產游戲失敗。</p><p>  根據玩具設置的游戲難度,在生產的終盤游戲中隨機挖取一定的空數據,空格越多,則游戲難度越大。</p><p>  游戲生產完畢以后,玩家開始填數字開始游戲,當玩家填寫完成,則開始進行游戲是否完成的判斷,在判斷過程中,只需要判斷當前空格中的數字是否與同行,同列和同小九宮格中的數字是否相同即可,若所有的單元格都

32、判斷成功,則玩家成功完成游戲。</p><p><b>  6.系統(tǒng)設計</b></p><p><b>  6.1設計思路</b></p><p>  先得到一個完整的數獨,然后根據難度需要,隨機地挖取一些空格出來,然后判斷是否符合條件(游戲規(guī)則),循環(huán)再輸出。</p><p>  6.2系統(tǒng)主要

33、類設計</p><p>  游戲框架基于MFC的對話框,在一個對話框中顯示九宮格和一些功能性按鈕,該程序主要包含GamePad類, sudokuDlg類和 SudokuGame類。</p><p>  6.2.1 GamePad類</p><p>  該類主要對數獨游戲的九宮格進行記錄和操作。</p><p>  九宮格的狀態(tài)一共分為5種:&

34、lt;/p><p>  enum CellType {</p><p>  ORIGINAL_CELL = 0, //原始數據單元格</p><p>  EDIT_CELL, //可編輯單元格</p><p>  ERROR_CELL, //輸入錯誤單元格</p><p>  CLICK_CELL

35、, //單機單元格</p><p>  PROMPT_CELL //提示輸入單元格</p><p><b>  };</b></p><p>  可編輯的單元格在每次點擊兩次之后會變成可編輯狀態(tài),玩家可通過鍵盤先單元格中輸入數字,提示單元格在玩家開啟提示功能之后,會在單元格的最下方顯示該單元格中可輸入的數字。</p>

36、;<p>  該類中記錄了九宮格操作需要的一些數據,具體包括:</p><p>  CSudokuGame m_sudo; //數獨游戲數據對象</p><p>  int m_x; //鼠標點擊x坐標</p><p>  int m_y; //鼠標點擊y坐標</p><p>  int

37、 m_row; //選擇行</p><p>  int m_col; //選擇列</p><p>  CRect m_rect[9][9]; //保存各個小方格坐標</p><p>  bool m_bCorrect[9][9]; //保存各個小方塊的輸入狀態(tài):輸入正確或者輸入錯誤</p><p&

38、gt;  CString m_proStr[2]; //保存提示字符串</p><p>  CRect m_proRect[2]; //保存顯示提示符的坐標</p><p>  int m_key; //鍵盤輸入</p><p>  int m_nClick; //記錄單機次數:單機兩次為輸入</p&g

39、t;<p>  BOOL m_bPrompt; //是否顯示提示</p><p><b>  ·</b></p><p>  同時,該類中記錄了九宮格操作的一些方法,具體包括:</p><p>  Bool GetRowCol(const CPoint point); //獲取鼠標單機單元格的行號和列號<

40、/p><p>  bool GetRowCol(int &row, int &col, const CPoint point); </p><p>  //外部進程獲取鼠標單機單元格的行號和列號</p><p>  bool GetPromptStrRect(const int row, const int col); //獲取提示符輸入&

41、lt;/p><p>  void DrawCell(const int row, const int col, const int invalue, const int type); //繪制單元格</p><p>  void Initialize(); // 單元格的初始化</p><p&g

42、t;  void MarkErrorCell(); //標記輸入錯誤的單元格</p><p>  void ShowTheComputeResult(const vector<vector<vector<int>>> &result, const bool bFinish); //顯示游戲自動完成的結果</p&

43、gt;<p>  在該類中,通過以上的變量和方法,對游戲界面的九宮格的狀態(tài)進行操作。</p><p>  6.2.2 SudokuDlg類</p><p>  該類主要對數獨游戲的整個運行邏輯進行控制,是整個對話框的控制類,在整個對話框中除了九宮格之外,還有8個按鈕,分別是“載入游戲”, “選擇游戲文件”,“退出游戲”,“保存游戲文件”,“完成游戲”,“保存正確結果”,“自動

44、計算數獨結果”和“隨機生成新游戲數據”,同時,還有一個復選框按鈕,玩家可以通過打開此開關顯示輸入提示。該類通過消息映射機制,分別對每一個按鈕做了相應的功能性處理,主要包括以下功能:</p><p>  void CSudokuDlg::OnBnClickedLoadgame()//加載原始游戲數據文件</p><p>  void CSudokuDlg::OnBnClickedChoose

45、()//選擇游戲數據文件進行游戲</p><p>  void CSudokuDlg::OnBnClickedNew()//生產新的游戲數據</p><p>  void CSudokuDlg::OnBnClickedSave()//保存新生產的游戲數據</p><p>  UINT Computing(LPVOID lpParam)//多線程計算數據結果</

46、p><p>  void CSudokuDlg::OnBnClickedCompute()//自動計算數據結果</p><p>  6.2.3 Sudokugame類</p><p>  該類是數獨游戲的規(guī)則控制類,主要用于控制游戲數據的生成,計算,判斷游戲成功失敗等等。</p><p>  主要包括以下的變量和函數:</p>&l

47、t;p>  int m_data[9][9]; //保存原始游戲數據</p><p>  int m_user[9][9]; //保存用戶輸入數據</p><p>  int m_bCompute; //判斷用戶是否終止自動計算</p><p>  bool m_bExit; //標志線程是否終止退出<

48、/p><p>  void Initialize();//初始化</p><p>  bool CheckInput(const int row, const int col, const int input); //判斷輸入的某個數據是否有效</p><p>  bool CheckCell(const int row, const int col);

49、 //判斷某一個單元格是否有錯</p><p>  bool CheckOriginalData(); //檢查原始數據的合法性</p><p>  int GetInputNum(const int row, const int col, vector<int> &integer); //獲取某個單元格所有可輸入的整數<

50、/p><p>  bool CheckTheResult(); //判斷用戶最終是否完成了游戲</p><p>  bool ComputeResult(vector<vector<vector<int>>> &results); //自動計算數獨結果</p><p>  bool CallRecur

51、rence(int *data, int count, vector<vector<vector<int>>> &results); //遞歸計算</p><p>  bool CallRecurrence(int *data, int count, int *result); //遞歸計算,用于生產數獨數據的中間計算過程</p><

52、;p>  void CreateSudokuData(); //自動隨機生產數據游戲數據</p><p>  void CopyToUser(); //將原始數據拷貝到用戶數據</p><p><b>  生產游戲數據代碼:</b></p><p><b>  思路分析:</b>&

53、lt;/p><p>  首先,確定一個9*9的正方形盤。</p><p>  第一行:取1~9個數字,然后把數字打亂放好到每一行每個格子里面。</p><p>  第二行開始:(因為有了第一行的限制,所以第二行開始就不能亂填了)。這時可以建立一個函數專門用來填數字,從第一列開始到第9列結束。</p><p>  函數的實現過程基本是這樣的:首先生

54、產一個1到9的隨機數,這時候判斷跟同一行前面填了的有沒有重復的,重復的重來,還要再判斷跟同一列的舔的數據有沒有重復的,重復的從來,總有一個會適合的。</p><p>  //遞歸計算,用于生產數獨數據的中間計算過程</p><p>  bool CSudokuGame::CallRecurrence(int *data, int count, int *result)</p>

55、<p><b>  {</b></p><p>  int a[9][9];</p><p>  memcpy(a, data, sizeof(a));</p><p>  if ( count == 81 )</p><p><b>  {</b></p><p&g

56、t;  memcpy(result, a, sizeof(a));</p><p>  return true;</p><p><b>  }</b></p><p>  unsigned int num = 10;</p><p>  int row = 0, col = 0;</p><p&g

57、t;  vector<int> mayInput;</p><p>  for ( int i = 0; i < 9; i++ )</p><p><b>  {</b></p><p>  for ( int j = 0; j < 9; j++ )</p><p><b>  {&l

58、t;/b></p><p>  if ( a[i][j] == 0 )</p><p><b>  {</b></p><p>  vector<int> integer;</p><p>  memcpy(m_user, a, sizeof(m_user));</p><p>

59、  GetInputNum(i, j, integer);</p><p>  if ( integer.empty() ) return false;</p><p>  if ( num > integer.size() )</p><p><b>  {</b></p><p>  num = integ

60、er.size();</p><p><b>  row = i;</b></p><p><b>  col = j;</b></p><p>  mayInput = integer;</p><p><b>  }</b></p><p><

61、b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  for (unsigned int i = 0; i < mayInput.size(); i++ )</p><p><b>  {</b

62、></p><p>  a[row][col] = mayInput[i];</p><p>  if ( CallRecurrence( (int *)a, count+1, result) ) return true;</p><p><b>  }</b></p><p>  return false;&

63、lt;/p><p><b>  }</b></p><p>  //自動隨機生成數獨游戲數據</p><p>  void CSudokuGame::CreateSudokuData()</p><p><b>  {</b></p><p>  int data[9][9];

64、</p><p>  memset(data, 0, sizeof(data));</p><p>  srand( (unsigned) time(NULL) );</p><p>  int num = (rand() % 17) + 25; //隨機產生20-41個隨機數</p><p>  int possible[9], i1

65、, i2, temp;</p><p>  for ( int i = 0; i < 9; i++ ) possible[i] = i+1;</p><p>  for ( int i = 0; i < 20; i++ )</p><p><b>  {</b></p><p>  i1 = rand(

66、) % 9;</p><p>  i2 = rand() % 9;</p><p>  temp = possible[i1];</p><p>  possible[i1] = possible[i2];</p><p>  possible[i2] = temp;</p><p><b>  }</

67、b></p><p>  bool bNon = true;</p><p>  int count = 9;</p><p>  int row, col;</p><p>  while ( bNon )</p><p><b>  {</b></p><p>

68、;  for ( int i = 0; i < 9; i++ )</p><p><b>  {</b></p><p>  col = rand() % 9;</p><p>  data[i][col] = possible[i];</p><p><b>  }</b></p>

69、;<p>  if ( CallRecurrence((int *)data, count, (int *)data) ) </p><p><b>  {</b></p><p>  bNon = false; </p><p><b>  break; </b></p><p>

70、<b>  }</b></p><p><b>  }</b></p><p>  //隨機挖去81-num個的洞</p><p>  for (int i = 0; i < (81-num); i++ )</p><p><b>  {</b></p>

71、<p>  row = rand() % 9;</p><p>  col = rand() % 9;</p><p>  while( data[row][col] == 0 )</p><p><b>  {</b></p><p>  row = rand() % 9;</p><p&

72、gt;  col = rand() % 9;</p><p><b>  }</b></p><p>  data[row][col] = 0;</p><p><b>  }</b></p><p>  memcpy(m_data, data, sizeof(data));</p>

73、<p>  memcpy(m_user, data, sizeof(data)); </p><p><b>  }</b></p><p>  //遞歸計算數獨結果</p><p>  bool CSudokuGame::CallRecurrence(int *data, int count, vector<vector<

74、;vector<int>>> &results)</p><p><b>  {</b></p><p>  if ( !m_bCompute ) return false;</p><p>  if ( results.size() >= MAX_NUM ) return true;</p&

75、gt;<p>  if ( count == 81 )</p><p><b>  {</b></p><p>  memcpy(m_user, data, sizeof(m_user));</p><p>  vector<vector<int>> result;</p><p>

76、  result.clear();</p><p>  result.resize(9);</p><p>  for ( int i = 0; i < 9; i++ )</p><p><b>  {</b></p><p>  for ( int j = 0; j < 9; j++ )</p>

77、<p><b>  {</b></p><p>  result[i].push_back(m_user[i][j]);</p><p><b>  }</b></p><p><b>  }</b></p><p>  results.push_back(res

78、ult);</p><p>  return true;</p><p><b>  }</b></p><p>  int a[9][9];</p><p>  memcpy(a, data, sizeof(a));</p><p>  unsigned int num = 10;</p&

79、gt;<p>  int row = 0, col = 0;</p><p>  vector<int> mayInput;</p><p>  for ( int i = 0; i < 9; i++ )</p><p><b>  {</b></p><p>  for ( int j

80、 = 0; j < 9; j++ )</p><p><b>  {</b></p><p>  if ( a[i][j] == 0 )</p><p><b>  {</b></p><p>  vector<int> integer;</p><p> 

81、 memcpy(m_user, a, sizeof(m_user));</p><p>  GetInputNum(i, j, integer);</p><p>  if ( integer.empty() ) return false;</p><p>  if ( num > integer.size() )</p><p>

82、<b>  {</b></p><p>  num = integer.size();</p><p><b>  row = i;</b></p><p><b>  col = j;</b></p><p>  mayInput = integer;</p>

83、<p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  bool bOK = false;</p><p>

84、;  for (unsigned int i = 0; i < mayInput.size(); i++ )</p><p><b>  {</b></p><p>  a[row][col] = mayInput[i];</p><p>  if ( CallRecurrence( (int *)a, count+1, results

85、) ) bOK = true;</p><p><b>  }</b></p><p>  return bOK;</p><p><b>  }</b></p><p>  //自動計算數獨游戲的可能解代碼:</p><p>  bool CSudokuGame::Com

86、puteResult(vector<vector<vector<int>>> &results)</p><p><b>  {</b></p><p>  m_bExit = false;</p><p>  results.clear();</p><p>  int d

87、ata[9][9];</p><p>  memcpy(data, m_data, sizeof(m_data)); </p><p>  int count = 0;</p><p>  for ( int i = 0; i < 9; i++ )</p><p><b>  {</b></p>&l

88、t;p>  for ( int j = 0; j < 9; j++ )</p><p><b>  {</b></p><p>  if ( m_data[i][j] > 0 ) count++;</p><p><b>  }</b></p><p><b>  }&

89、lt;/b></p><p>  if ( CallRecurrence((int *)data, count, results) )</p><p><b>  {</b></p><p>  m_bExit = true;</p><p>  return true;</p><p>&

90、lt;b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  m_bExit = true;</p><p>  return false;</p><p><b>  }<

91、;/b></p><p><b>  }</b></p><p>  //獲取某個單元格中可以輸入的數據代碼</p><p>  int CSudokuGame::GetInputNum(const int row, const int col, vector<int> &integer)</p><

92、;p><b>  {</b></p><p>  if ( (col >= 9) || (row >= 9) || (col < 0) || (row < 0) ) return 0;</p><p>  int num = 0;</p><p>  integer.clear();</p><

93、;p>  int line[9];</p><p>  memset(line, 1, sizeof(line));</p><p>  int i = 0, j = 0, temp;</p><p>  for( i = 0; i < 9; i++)</p><p><b>  {</b></p&g

94、t;<p>  temp = m_user[i][col];</p><p>  if( (row != i) && temp > 0 ) line[temp-1] = 0;</p><p><b>  }</b></p><p>  for( i = 0; i < 9; i++)</p>

95、;<p><b>  {</b></p><p>  temp = m_user[row][i];</p><p>  if( (col != i) && temp > 0 ) line[temp-1] = 0;</p><p><b>  }</b></p><p

96、>  int t1 = row / 3, t2 = col / 3;</p><p>  for( i = t1*3; i < (t1*3+3); i++)</p><p><b>  {</b></p><p>  if ( row == i ) continue;</p><p>  for( j =

97、t2*3; j < (t2*3+3); j++)</p><p><b>  {</b></p><p>  if ( col == j ) continue;</p><p>  temp = m_user[i][j];</p><p>  if( temp > 0 ) line[temp-1] = 0

98、;</p><p><b>  }</b></p><p><b>  }</b></p><p>  for ( i = 0; i < 9; i++ )</p><p><b>  {</b></p><p>  if ( line[i] !=

99、0 )</p><p><b>  {</b></p><p>  integer.push_back(i+1);</p><p><b>  num++;</b></p><p><b>  }</b></p><p><b>  }<

100、/b></p><p>  return num;</p><p><b>  }</b></p><p>  //檢查用戶是否正確完成數據代碼</p><p>  bool CSudokuGame::CheckTheResult()</p><p><b>  {</b&g

101、t;</p><p>  int i = 0, j = 0;</p><p>  for( i =0; i < 9; i++)</p><p><b>  {</b></p><p>  for( j = 0; j < 9; j++)</p><p><b>  {</

102、b></p><p>  if( m_user[i][j] == 0 ) return false;</p><p><b>  else</b></p><p><b>  {</b></p><p>  if( !CheckInput(i, j, m_user[i][j]) ) retu

103、rn false;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  return true;</p><p><b>  }</b><

104、/p><p>  7.系統(tǒng)主要技術特色</p><p>  游戲采用了MFC框架搭建,有著較好的界面顯示,可以給用戶更好的游戲體驗,相對于傳統(tǒng)的游戲設計,游戲中加入了顯示輸入提示功能,可以幫助水平不高的玩具更容易的完成游戲,使初學者更容易完成數獨游戲,體驗到數獨游戲的樂趣。</p><p><b>  8.結論</b></p><

105、;p>  畢業(yè)設計是對我們四年所學知識最后一次綜合性檢測盒實際應用能力的考察。我們這次設計的課題是“數獨游戲的設計與開發(fā)”,該課題使我對所學的知識有了一個比較系統(tǒng)的認識和理解。涉及了軟件工程,C++語言,數據庫等科目,綜合能力有了進一步提高,同時使我學會了如何使用所學的知識去解決一些實際問題,增加了我們的動手能力。</p><p>  本次的數獨游戲雖然設計簡單,但是在這次設計中綜合了所學知識的理論和基礎。

106、通過對本次游戲的設計,將所學的知識運用到實際生活去了。從而知道自己對知識的掌握情況。經這次設計,讓專業(yè)知識與實踐結實,讓專業(yè)知識得到了更好的消化和更牢固的掌握。而且我明白了知識不是單一的,它是相互聯(lián)系的,學科與學科之間都有著內在聯(lián)系。計算機是一門非常復雜,龐大的學科,一項課題往往需要多項技術才可以完成。在設計階段,我通過對課程的深層分析與研究,使我又對多門技術有了一定的了解。在遇到困難時,我懂得了該怎么樣去應付,如何去查找和分析相關資料

107、。</p><p>  在設計過程中,遇到了很多的各種問題,這不失是一種好的現象,因為在設計時出現的問題越多,最后成功率就越大。常說在問題中進步,在失敗中成長,亦是如此。</p><p>  在這次設計中我得到了老師和同學的指導和幫助,使我們認識到團隊精神的重要性,因為一個人所學的知識不可能面面俱到的,只有通過合作,發(fā)揮自己的優(yōu)點,體現團隊精神,才能使工作做得更為出色。通過這次設計,我學到

108、了許多書本上學不到的知識,增強了自己的動手能力和自信心。通過這次設計使我們能力有了很大的提高,為我們以后走上崗位打下了扎實的基礎</p><p>  非常感謝老師給我們這次鍛煉的機會,最后在老師的指導下完成了自己的設計任務,但由于自己的知識水平有限,有許多不足之處,懇請老師多多指教!</p><p><b>  參考文獻</b></p><p>

109、;  [1].羅斌,Visual C++編程技巧精選500例,北京:中國水利水電出版社,2005.1</p><p>  [2].劉加海,余建軍,Visual C++程序設計基礎,北京:科學出版社,2003.8</p><p>  [3].譚鋒,章偉聰,Visual C++程序設計實訓教程,北京:科學出版社,2003.8</p><p>  [4].肖宏偉,Visu

110、al C++實效編程百例,北京:人民郵電出版社,2004.8</p><p>  [5].劉加海,羅曉芳,面向對象的程序設計C++,北京:科學出版社,2003.8</p><p>  [6].王超龍,陳志華,Visual C++入門與提高,北京:人民郵電出版社,2002.6</p><p>  [7].(美國)德洛拉,游戲編程精粹,人民郵電出版社,2003.12&l

111、t;/p><p>  [8].(美國)斯塔勒,游戲編程中的數理應用,紅旗出版社,2005.3</p><p>  [9].(美國)柯姆斯,游戲編程精粹,人民郵電出版社,2005.3</p><p>  [10].(美國)羅比斯,C++游戲編程,清華大學出版社,2004.9</p><p><b>  致謝</b></p

112、><p>  至此,數獨游戲的畢業(yè)設計已經全部結束。這次畢業(yè)設計是對我大學四年來所學知識的回顧和總結,在此基礎上進行了綜合應用和拓展。在這次畢業(yè)設計過程中,我掌握了一般游戲設計的方法,同時也對我實踐應用能力提出來更高的要求,開拓了視野,拓展了知識面。再次感謝三年來對我辛勤培養(yǎng)和教育的所有老師,感謝給予我?guī)椭凸膭畹乃型瑢W。</p><p>  在設計過程中我得到了馮永老師和有關同學的支持和幫

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論