


There are two ways to play the guessing game:
The first one: two people play, one party gives the number and the other party guesses. The person who guesses the number must think of a number with a specified number of digits. The number can be repeated and the guesser cannot know it.
Anyone who guesses can start guessing. Every time a number is guessed, the person who guesses the number must say whether it is greater or less than the number.
Second type: Two people play, one party gives the number and the other party guesses. The person who guesses the number must first think of a 4-digit number without repeated numbers, and cannot let the guesser know. Anyone who guesses
can start guessing. Every time you guess a number, the person who guesses the number will give out how many A's and how many B's according to this number. The number before A indicates the number of numbers in the correct position, and the number before
The number represents the number of numbers with correct numbers but incorrect positions. For example, the correct answer is 5234, and the guesser guesses 5346, which is 1A2B. One of the 5 bits
is set correctly, which is recorded as 1A, and the two digits 3 and 4 are The number is correct, but the position is not, so it is recorded as 2B, which adds up to 1A2B. The person who guesses then continues to guess based on the number
of the questioner until he guesses correctly.
The following is the PHP code implementation:
<?php // 标准输入流和标准输出流 $stdin = null; $stdout = null; /** * 初始化 IO 流 */ function init() { global $stdin; global $stdout; $stdin = fopen('php://stdin', 'r'); $stdout = fopen('php://stdout', 'w'); } /** * 关闭 IO 流 */ function destroy() { global $stdin; global $stdout; if(is_resource($stdin)) { fclose($stdin); } if(is_resource($stdout)) { fclose($stdout); } } /** * 从命令行读取一行数据 */ function read() { global $stdin; $line = fgets($stdin); return trim($line, PHP_EOL); //去除换行符 } /** * 向命令行输出一行数据 */ function write($line) { global $stdout; // 转换编码 if(stripos(PHP_OS, 'winnt') !== false) { $line = iconv('UTF-8', 'GBK', $line); } fwrite($stdout, $line . PHP_EOL); } /** * 第一种玩法 * @param $count 位数 */ function guess_the_number($count = 2) { // 随机生成一个 $count 位数 $min = pow(10, $count - 1); $max = pow(10, $count) - 1; $number = rand($min, $max); init(); while(1) { write(sprintf('Please input your number (%s-bit digit), q or quit exit: ', $count)); $readStr = read(); // exit program if($readStr == 'q' || $readStr == 'quit') { break; } $readInt = intval($readStr); if($readInt > $number) { write('大了'); } else if($readInt < $number) { write('小了'); } else { write('恭喜你,猜对了!'); write('Input c continue to play'); $readStr = read(); if($readStr == 'c' || $readStr == 'continue') { $number = rand($min, $max); } else { break ; } } } destroy(); } /** * 得到一个没有重复数字的四位数 */ function getRandNumber() { $num = rand(1, 9); $array = array_diff(array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9), [$num]); shuffle($array); $subarr = array_slice($array, 0, 3); //再取 3 个数字 $str = implode('', array_merge([$num], $subarr)); return intval($str); } /** * 第二种玩法 */ function guess_the_number2() { $number = getRandNumber(); $len = 4; //四位数 init(); while(1) { write(sprintf('Please input your number (%s-bit digit), q or quit exit: ', $len)); $readStr = read(); // exit program if($readStr == 'q' || $readStr == 'quit') { break; } $readInt = intval($readStr); if($readInt == $number) { write('恭喜你,猜对了!'); write('Input c continue to play'); $readStr = read(); if($readStr == 'c' || $readStr == 'continue') { $number = getRandNumber(); } else { break ; } } else { // 判断 几A几B $readInt = str_pad($readInt, $len, '0', STR_PAD_LEFT); //不足四位的补足四位 $number = strval($number); $readArr = str_split($readInt, 1); // cast to array $numArr = str_split($number, 1); $aval = 0; // 几A $bval = 0; // 几B for($i = 0; $i < $len; $i++) { if($readArr[$i] == $numArr[$i]) { $aval++; unset($readArr[$i], $numArr[$i]); } } $bval = count(array_intersect($readArr, $numArr)); write(sprintf('%sA%sB', $aval, $bval)); } } destroy(); } if(PHP_SAPI == 'cli') { // guess_the_number(1); guess_the_number2(); } else { echo 'Please run under command line!'; exit; }
The above is the detailed content of Code example sharing for implementing number guessing game in PHP. For more information, please follow other related articles on the PHP Chinese website!

APHPDependencyInjectionContainerisatoolthatmanagesclassdependencies,enhancingcodemodularity,testability,andmaintainability.Itactsasacentralhubforcreatingandinjectingdependencies,thusreducingtightcouplingandeasingunittesting.

Select DependencyInjection (DI) for large applications, ServiceLocator is suitable for small projects or prototypes. 1) DI improves the testability and modularity of the code through constructor injection. 2) ServiceLocator obtains services through center registration, which is convenient but may lead to an increase in code coupling.

PHPapplicationscanbeoptimizedforspeedandefficiencyby:1)enablingopcacheinphp.ini,2)usingpreparedstatementswithPDOfordatabasequeries,3)replacingloopswitharray_filterandarray_mapfordataprocessing,4)configuringNginxasareverseproxy,5)implementingcachingwi

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl

TomakePHPapplicationsfaster,followthesesteps:1)UseOpcodeCachinglikeOPcachetostoreprecompiledscriptbytecode.2)MinimizeDatabaseQueriesbyusingquerycachingandefficientindexing.3)LeveragePHP7 Featuresforbettercodeefficiency.4)ImplementCachingStrategiessuc

ToimprovePHPapplicationspeed,followthesesteps:1)EnableopcodecachingwithAPCutoreducescriptexecutiontime.2)ImplementdatabasequerycachingusingPDOtominimizedatabasehits.3)UseHTTP/2tomultiplexrequestsandreduceconnectionoverhead.4)Limitsessionusagebyclosin

Dependency injection (DI) significantly improves the testability of PHP code by explicitly transitive dependencies. 1) DI decoupling classes and specific implementations make testing and maintenance more flexible. 2) Among the three types, the constructor injects explicit expression dependencies to keep the state consistent. 3) Use DI containers to manage complex dependencies to improve code quality and development efficiency.

DatabasequeryoptimizationinPHPinvolvesseveralstrategiestoenhanceperformance.1)Selectonlynecessarycolumnstoreducedatatransfer.2)Useindexingtospeedupdataretrieval.3)Implementquerycachingtostoreresultsoffrequentqueries.4)Utilizepreparedstatementsforeffi


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.
