由计算机“想”一个四位数,请人猜这个四位数是多少。人输入四位数字后,计算机首先 判断这四位数字中有几位是猜对了,并且在对的数字中又有几位位置也是对的,将结果显示出来,给人以提示,请人再猜,直到人猜出计算机所想的四位数是多少为止。例如:计算机“想”了一个“1234”请人猜,可能的提示如下:人猜的整数计算机判断有几个数字正确有几个位置正确1122 2 1 3344 2 1 3312 3 0 4123 4 0 1243 4 2 1234 4 4游戏结束请编程实现该游戏。
游戏结束时,显示人猜一个数用了几次。*问题分析与算法设计问题本身清楚明了。判 断相同位置上的数字是否相同不需要特殊的算法。只要截取相同位置上的数字进行比较即可。但在判 断几位数字正确时,则应当注意:计算机所想的是“1123”,而人所猜的是“1576”,则正确的数字只有1位。程序中 截取计算机所想的数的每位数字与人所猜的数字按位比较。若有两位数字相同,则要 记信 所猜中数字的位置,使该位数字只能与一位对应的数字“相同”。当截取下一位数字进行比较时,就不应再与上述位置上的数字进行比较,以避免 所猜的数中的一位与对应数中多位数字“相同”
#include <iostream>
#include <string>
#include <ctime>
#include <cstdlib>using namespace std;int main() {srand(time(0));string targetNumber;int guessCount = 0;// 生成随机的四位数作为目标数字for (int i = 0; i < 4; i++) {char digit = '0' + rand() % 10;targetNumber += digit;}while (true) {string guessNumber;cout << "请猜一个四位数: ";cin >> guessNumber;if (guessNumber.length() != 4) {cout << "请输入一个四位数!" << endl;continue;}int correctDigitsCount = 0;int correctPositionsCount = 0;for (int i = 0; i < 4; i++) {if (guessNumber[i] == targetNumber[i]) {correctPositionsCount++;}if (targetNumber.find(guessNumber[i]) != string::npos) {correctDigitsCount++;}}cout << "你猜的整数计算机判断有几个数字正确有几个位置正确: " << correctDigitsCount << " " << correctPositionsCount << endl;if (correctPositionsCount == 4) {cout << "恭喜你猜对了!" << endl;break;}guessCount++;}cout << "你一共猜了 " << guessCount << " 次。" << endl;return 0;
}