# 迴圈與決策指令的應用--猜數字遊戲

電腦裡面有一個有趣的功能就是「隨機數」。隨機數顧名思義，就是讓電腦隨機地設定一個數值，而這個數值事先我們並沒有辦法知道，如此就可以增加我們在設計遊戲類程式的有趣性。在Scratch中，隨機數的積木是這個；

![](https://3758851535-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-LMo8PFR2UvTkWwSK8m0%2F-LQ6k-CeFzjOEsO8s5is%2F-LQ6l2vjdZvdey1dhQrR%2F2018-10-31_09-36-45.png?alt=media\&token=e7c0181e-0abd-4e83-9a59-18426735d648)

這個積木我們可以直接使用在其它的積木中，例如，下面這個例子是讓我們的角色在程式執行時一直不斷地變化位置：

![](https://3758851535-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-LMo8PFR2UvTkWwSK8m0%2F-LQ6k-CeFzjOEsO8s5is%2F-LQ6llJaTyG084miNwU1%2F2018-10-31_09-39-52.png?alt=media\&token=a10622b6-1856-41b7-8034-4f9920c15666)

但是一般來說，我們會先把隨機數的值儲存在變數中再拿出來使用，如下：

![](https://3758851535-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-LMo8PFR2UvTkWwSK8m0%2F-LQ6k-CeFzjOEsO8s5is%2F-LQ6nrwGMssRLFcOjMTV%2F2018-10-31_09-49-01.png?alt=media\&token=e50b4d4f-5060-443c-b675-a14034c9309c)

這樣做的好處是，在變數中的資料可以多次取用，而不會每次取用的時候都會是不同的隨機數。接下來，我們來看看猜數字遊戲如何設計。首先，使用隨機數設定一個0-99之間的變數：

![](https://3758851535-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-LMo8PFR2UvTkWwSK8m0%2F-LQ6k-CeFzjOEsO8s5is%2F-LQ6s7_Q4aMFPs4Oomyc%2F2018-10-31_10-07-38.png?alt=media\&token=3e6f7174-032a-416e-8e75-7b287baaed87)

然後就讓貓咪開始問問題，如下：

![](https://3758851535-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-LMo8PFR2UvTkWwSK8m0%2F-LQ6k-CeFzjOEsO8s5is%2F-LQ6sNCpbiPaWX5dgqvp%2F2018-10-31_10-08-47.png?alt=media\&token=161f141c-0b0c-46c9-85ef-dd3cd6c0dc28)

把玩家的回答放到guess這個變數中，如下：

![](https://3758851535-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-LMo8PFR2UvTkWwSK8m0%2F-LQ6k-CeFzjOEsO8s5is%2F-LQ6scFTbW2ZFWyDdPYi%2F2018-10-31_10-09-51.png?alt=media\&token=e00b14c6-1a4d-4b62-97b1-f768f4baa0f9)

接著就是要判斷玩家的回答和真正的答是是否一樣，我們使用選擇積木如下：

![](https://3758851535-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-LMo8PFR2UvTkWwSK8m0%2F-LQ6k-CeFzjOEsO8s5is%2F-LQ6tF7CBUKqiAsxQtA_%2F2018-10-31_10-12-35.png?alt=media\&token=cf5ac171-63ba-49fd-a40c-9d2c9a2326a3)

可是，這樣只有猜一次的機會不好玩，我們想要讓玩家可以一直猜，直到答對為止。此種情況就需要迴圈的介入，如下：

![](https://3758851535-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-LMo8PFR2UvTkWwSK8m0%2F-LQ6k-CeFzjOEsO8s5is%2F-LQ6toRwikIIhZffRW5T%2F2018-10-31_10-15-04.png?alt=media\&token=c3392dd1-8b18-4fec-acb3-7ef8b5e49f72)

在上面這個例子中我們用了一個無窮的迴圈讓玩家一直猜，直到猜中的時候才會使用「停止全部」這個積木來停止程式的執行。可是一個問題就是，猜了數字之後如果猜錯並沒有任何的回饋，這樣子根本就沒有辦法好好地猜，因此，在猜錯數字的時候，其實需要再加上一個選擇，依照猜測數字和答案之間的關係來給予玩家回饋，這樣才是一個比較好玩的猜數字遊戲。修改的版本如下：

![](https://3758851535-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-LMo8PFR2UvTkWwSK8m0%2F-LQ6k-CeFzjOEsO8s5is%2F-LQ6ugVLjTunmbn8otZn%2F2018-10-31_10-18-53.png?alt=media\&token=4d587ba9-2d89-4d67-8c25-1f53c4d4c43f)

上面這樣子的程式就可以進行一個有趣的猜數字了。上面這個程式利用不同的迴圈設計還有不同的寫法，同學們可以比較看看：

![](https://3758851535-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-LMo8PFR2UvTkWwSK8m0%2F-LQ6k-CeFzjOEsO8s5is%2F-LQ6vv6c2_nxgaOcrQSa%2F2018-10-31_10-24-13.png?alt=media\&token=49396115-68d1-4c49-9995-cc470090bc3b)

同學們可以看出邏輯上不一樣的地方嗎？由上面這樣的程式設計方式，我們還可以把它再進階，加上一個迴圈，讓這個遊戲可以一直玩，直到玩家回答「n」為止：

![](https://3758851535-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-LMo8PFR2UvTkWwSK8m0%2F-LQ6k-CeFzjOEsO8s5is%2F-LQ6xA1M8rEZ70mOH9de%2F2018-10-31_10-28-53.png?alt=media\&token=233498a3-6954-492b-8de0-4f09288c090d)

有了這個程式做基礎，同學們是否會再加上一些記錄玩家的答對次數以及答錯次數的顯示呢？


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://nkust.gitbook.io/csx/quan-ce-zhi-ling-de-yong-cai-zi.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
