当前位置: 首页 > news >正文

用c++实现五子棋小游戏

五子棋是一款经典小游戏,今天我们就用c++实现简单的五子棋小游戏

目录

用到的算法:

思路分析

定义变量 

开始写代码

 

完整代码 

结果图:


用到的算法:

  1. 合法移动的判断:isValidMove 函数通过检查指定位置是否在棋盘范围内,并且该位置是否为空位来确定是否为合法的移动。

  2. 获胜条件的检查:checkWin 函数通过遍历四个方向(水平、垂直、两个对角线)来检查是否存在连续的五个相同类型的棋子。它使用两个 while 循环,一个向一个方向移动,另一个向相反方向移动,以统计横向、纵向和对角线上相同类型棋子的数量。

  3. 棋盘状态的打印:printBoard 函数使用嵌套的 for 循环来遍历棋盘的每个位置,并输出相应的符号来表示该位置的状态。

  4. 棋盘是否已满的检查:isBoardFull 函数使用嵌套的 for 循环来遍历棋盘的每个位置,检查是否存在空位。如果不存在空位,则棋盘已满

思路分析

  1. 初始化:创建一个空的棋盘,大小为15x15,用二维向量表示。初始时所有位置都是空位。

  2. 循环游戏:进入一个无限循环,在每一轮中依次执行以下步骤:

    • 打印当前棋盘状态;
    • 根据当前轮到的玩家,提示玩家输入下子位置;
    • 检查输入的下子位置是否合法,即在棋盘范围内且为空位,如果不合法则提示重新输入;
    • 在棋盘上下子,并判断是否获胜或棋盘已满;
    • 如果获胜或棋盘已满,根据情况打印相应的信息,并结束游戏。
  3. 判断获胜和棋盘是否已满:

    • 每次下子后,调用 checkWin 函数来检查当前位置是否连成五子,如果是则返回获胜;
    • 如果没有获胜,则调用 isBoardFull 函数来判断棋盘是否已满,如果棋盘已满则返回平局。
  4. 输出棋盘状态:

    • printBoard 函数使用嵌套的 for 循环遍历棋盘的每个位置,根据该位置的状态输出相应的符号,用于展示当前棋盘状态

定义变量 

  • BOARD_SIZE 定义了棋盘的大小,这里设置为15x15。
  • EMPTYBLACK 和 WHITE 定义了棋盘上的三种状态:空位、黑棋和白棋。
  • board 是一个二维向量,表示棋盘,初始时所有位置都是空位。
  • isValidMove 函数用于判断某个位置是否可以下子。合法的位置必须在棋盘范围内,并且为空位。
  • checkWin 函数用于判断某个位置下子后是否获胜。它检查当前位置在四个方向上(水平、垂直、两个对角线)是否有连续的连续的五个相同类型棋子。如果有则返回 true,否则返回 false。
  • printBoard 函数用于打印当前棋盘的状态。
  • isBoardFull 函数用于判断棋盘是否已经满了(即没有空位),如果棋盘已满,则返回 true,否则返回 false。
  • main 函数是程序的入口。它使用一个无限循环,每次循环轮流让玩家下子,然后判断是否游戏结束。如果有一方获胜或者棋盘已满,则打印相应的信息,并结束游戏。

开始写代码

void printBoard() {for (int i = 0; i < BOARD_SIZE; i++) {for (int j = 0; j < BOARD_SIZE; j++) {cout << board[i][j] << " ";}cout << endl;}cout << endl;
}

 

这段代码为打印棋盘状态的函数printBoard(),使用了嵌套的循环来遍历棋盘,并输出每个位置的状态。

具体的实现逻辑如下:

  1. 外层循环for (int i = 0; i < BOARD_SIZE; i++)遍历棋盘的行数,从第一行开始到最后一行。
  2. 内层循环for (int j = 0; j < BOARD_SIZE; j++)遍历棋盘的列数,从第一列开始到最后一列。
  3. 在内层循环中,通过board[i][j]获取当前位置的状态值,并使用cout输出该状态值。
  4. 输出一个空格,以分隔不同位置的状态值。
  5. 内层循环结束后,通过cout << endl;输出换行符,以换行显示下一行的棋盘状态。
  6. 外层循环结束后,通过cout << endl;再次输出一个换行符,以在棋盘状态的输出之间添加空行。

这样,调用printBoard()函数可以按照指定格式输出当前棋盘的状态。每个位置上的状态值可以是空格、X或O等字符,表示空位、玩家1和玩家2的棋子。通过这个函数,可以直观地展示游戏棋盘的状态给玩家。

bool isValidMove(int row, int col) {return (row >= 0 && row < BOARD_SIZE && col >= 0 && col < BOARD_SIZE && board[row][col] == EMPTY);
}

 

这段代码是用于判断玩家落子是否合法的函数isValidMove(row, col),其中rowcol分别表示玩家输入的坐标值。

具体的实现逻辑如下:

  1. 首先,通过row >= 0 && row < BOARD_SIZE && col >= 0 && col < BOARD_SIZE判断玩家输入的坐标值是否在棋盘范围内。如果超出了棋盘范围,则此次落子不合法。
  2. 否则,通过board[row][col] == EMPTY判断该位置是否已有棋子(即状态值是否为EMPTY)。如果该位置上没有棋子,则此次落子合法,返回true
  3. 如果该位置上已经有棋子,则此次落子不合法,返回false

通过这个函数,可以快速判断玩家输入的坐标是否合法。如果不合法,则需要提示玩家重新输入坐标;如果合法,则可以继续进行游戏。

 


bool checkWin(int row, int col, char player) {int directions[4][2] = {{1, 0}, {0, 1}, {1, 1}, {-1, 1}};for (int i = 0; i < 4; i++) {int count = 1;int dx = directions[i][0], dy = directions[i][1];int r = row + dx, c = col + dy;while (r >= 0 && r < BOARD_SIZE && c >= 0 && c < BOARD_SIZE && board[r][c] == player) {count++;r += dx;c += dy;}dx = -dx, dy = -dy;r = row + dx, c = col + dy;while (r >= 0 && r < BOARD_SIZE && c >= 0 && c < BOARD_SIZE && board[r][c] == player) {count++;r += dx;c += dy;}if (count >= 5)return true;}return false;
}

 

这段代码是用于检查玩家是否取得胜利的函数checkWin(row, col, player),其中rowcol表示最后一次落子的坐标,player表示当前玩家的符号。

具体的实现逻辑如下:

  1. 首先,定义一个二维数组directions[4][2]来表示四个方向,分别为向下、向右、右下、左下。每个方向由两个元素组成,分别表示在行方向和列方向上的增量。
  2. 使用一个循环遍历四个方向。
  3. 在循环内部,初始化一个计数器count为1,表示已经有一颗当前玩家的棋子。
  4. 根据当前方向的增量(dx, dy),计算下一个检查的位置(r, c),并检查该位置是否在棋盘范围内且值等于当前玩家的符号。
  5. 如果满足条件,将计数器count加1,并更新下一个位置(r, c)为当前位置加上增量(dx, dy)
  6. 重复步骤4和步骤5,直到碰到越界或者不是当前玩家的棋子。
  7. 然后,将增量(dx, dy)取相反数,即改变方向。
  8. 再次计算下一个检查的位置(r, c),并检查该位置是否在棋盘范围内且值等于当前玩家的符号。
  9. 如果满足条件,将计数器count加1,并更新下一个位置(r, c)为当前位置加上增量(dx, dy)
  10. 重复步骤8和步骤9,直到碰到越界或者不是当前玩家的棋子。
  11. 检查计数器count是否大于等于5,如果是,则表示当前玩家在其中一个方向上取得了胜利,返回true
  12. 如果四个方向都遍历完毕,仍未满足取胜条件,则返回false

通过这个函数,可以判断当前玩家是否在最后一次落子后取得了胜利。根据游戏规则,只有当任意一方在横、竖、斜对角线方向上连续五个棋子时才算获胜。

完整代码 

#include <iostream>
#include <vector>using namespace std;const int BOARD_SIZE = 15;
const char EMPTY = '-';
const char BLACK = 'X';
const char WHITE = 'O';vector<vector<char> > board(BOARD_SIZE, vector<char>(BOARD_SIZE, EMPTY));bool isValidMove(int row, int col) {return (row >= 0 && row < BOARD_SIZE && col >= 0 && col < BOARD_SIZE && board[row][col] == EMPTY);
}bool checkWin(int row, int col, char player) {int directions[4][2] = {{1, 0}, {0, 1}, {1, 1}, {-1, 1}};for (int i = 0; i < 4; i++) {int count = 1;int dx = directions[i][0], dy = directions[i][1];int r = row + dx, c = col + dy;while (r >= 0 && r < BOARD_SIZE && c >= 0 && c < BOARD_SIZE && board[r][c] == player) {count++;r += dx;c += dy;}dx = -dx, dy = -dy;r = row + dx, c = col + dy;while (r >= 0 && r < BOARD_SIZE && c >= 0 && c < BOARD_SIZE && board[r][c] == player) {count++;r += dx;c += dy;}if (count >= 5)return true;}return false;
}void printBoard() {for (int i = 0; i < BOARD_SIZE; i++) {for (int j = 0; j < BOARD_SIZE; j++) {cout << board[i][j] << " ";}cout << endl;}cout << endl;
}bool isBoardFull() {for (int i = 0; i < BOARD_SIZE; i++) {for (int j = 0; j < BOARD_SIZE; j++) {if (board[i][j] == EMPTY)return false;}}return true;
}int main() {int row, col;char currentPlayer = BLACK;while (true) {printBoard();cout << "Player " << currentPlayer << ", enter your move (row col): ";cin >> row >> col;if (!isValidMove(row, col)) {cout << "Invalid move! Try again." << endl;continue;}board[row][col] = currentPlayer;if (checkWin(row, col, currentPlayer)) {cout << "Player " << currentPlayer << " wins!" << endl;break;} else if (isBoardFull()) {cout << "It's a draw!" << endl;break;}currentPlayer = (currentPlayer == BLACK) ? WHITE : BLACK;}printBoard();return 0;
}

 

在这个五子棋游戏代码中,可以通过以下方式进行输入和输出:

输入:

  1. 玩家输入下子位置:可以通过命令行提示玩家输入坐标,例如,要求玩家输入行和列的数字,表示下子位置的坐标。
  2. 其他玩家操作:例如,要求玩家输入指令来选择重新开始游戏或退出游戏。

输出:

  1. 打印当前棋盘状态:使用嵌套的循环遍历棋盘,根据棋盘上每个位置的状态输出相应的符号,可以使用空格、X和O等字符来表示空位、玩家1和玩家2的棋子。
  2. 提示玩家操作:例如,提示玩家输入坐标来下子,或者提示玩家输入指令以进行其他操作。
  3. 游戏结果输出:当游戏结束时,根据游戏结果输出胜利者或者平局信息。
  4. 错误提示:如果玩家输入了无效的指令或下子位置,可以输出错误提示信息,要求玩家重新输入。

在代码中,可以使用适当的输入函数,如input()来接收玩家输入,并使用适当的输出函数,如print()来输出信息到控制台。通过合理地组织输入和输出,可以实现与玩家的有效交互,并提供友好的游戏体验。

结果图:

如果想要更加华丽美观的代码,关注博主赞赏2元回复“五子棋华丽代码”即可。

相关文章:

用c++实现五子棋小游戏

五子棋是一款经典小游戏&#xff0c;今天我们就用c实现简单的五子棋小游戏 目录 用到的算法&#xff1a; 思路分析 定义变量 开始写代码 完整代码 结果图&#xff1a; 用到的算法&#xff1a; 合法移动的判断&#xff1a;isValidMove 函数通过检查指定位置是否在棋盘范…...

Android 12.0 SystemUI下拉状态栏定制化之隐藏下拉通知栏布局功能实现(二)

1.前言 在12.0的系统定制化开发中,由于从12.0开始SystemUI下拉状态栏和11.0的变化比较大,所以可以说需要从新分析相关的SystemUI的 布局,然后做分析来实现不同的功能,今天就开始实现关于隐藏SystemUI下拉状态栏中的通知栏布局系列二,去掉下拉状态栏中 通知栏部分 白色的…...

通过finalshell快速在ubuntu上安装jdk1.8

这篇文章主要介绍一下怎么通过finalshell连接ubuntu&#xff0c;然后在ubuntu上安装jdk1.8&#xff0c;让不熟悉linux操作系统的童鞋也能快速地完成安装。 目录 一、准备一台虚拟机 二、安装finalshell远程连接工具 三、获取ubuntu虚拟机的ip地址 四、通过finalshell连接u…...

【Linux从入门到精通】多线程 | 线程互斥(互斥锁)

上篇文章我们对线程 | 线程介绍&线程控制介绍后&#xff0c;本篇文章将会对多线程中的线程互斥与互斥锁的概念进行详解。同时结合实际例子解释了可重入与不被重入函数、临界资源与临界区和原子性的概念。希望本篇文章会对你有所帮助。 文章目录 引入 一、重入与临界 1、1 可…...

Echarts 散点图的详细配置过程

文章目录 散点图 简介配置步骤简易示例 散点图 简介 Echarts散点图是一种常用的数据可视化图表类型&#xff0c;用于展示两个或多个维度的数据分布情况。散点图通过在坐标系中绘制数据点的位置来表示数据的关系。 Echarts散点图的特点如下&#xff1a; 二维数据展示&#xff…...

Nginx详解 五:反向代理

文章目录 1. 正向代理和反向代理1.1 正向代理概述1.1.1 什么是正向代理1.1.2 正向代理的作用1.1.3 正向代理的基本格式 1.2 反向代理概述1.2.1 什么是反向代理1.2.2 反向代理可实现的功能1.2.3 反向代理的可用模块 2. 配置反向代理2.1 反向代理配置参数2.1.1 proxy_pass2.1.2 其…...

【PDF密码】PDF文件打开之后不能打印,怎么解决?

正常的PDF文件是可以打印的&#xff0c;如果PDF文件打开之后发现文件不能打印&#xff0c;我们需要先查看一下自己的打印机是否能够正常运行&#xff0c;如果打印机是正常的&#xff0c;我们再查看一下&#xff0c;文件中的打印功能按钮是否是灰色的状态。 如果PDF中的大多数功…...

深入解析 qsort 函数(下),用冒泡排序模拟实现 qsort 函数

前言&#xff1a;对于库函数有适当了解的朋友们&#xff0c;对于 qsort 函数想必是有认知的&#xff0c;因为他可以对任意数据类型进行排序的功能属实是有点厉害的&#xff0c;本次分享&#xff0c;笔者就给大家带来 qsort 函数的全面的解读 本次知识的分享笔者分为上下俩卷文章…...

Azure + React + ASP.NET Core 项目笔记一:项目环境搭建(二)

有意义的标题 pnpm 安装umi4 脚手架搭建打包语句变更Visual Studio调试Azure 设置变更发布 pnpm 安装 参考官网&#xff0c;或者直接使用npm安装 npm install -g pnpmumi4 脚手架搭建 我这里用的umi4&#xff0c;官网已附上 这里需要把clientapp清空&#xff0c;之后 cd Cl…...

Vmware通过VMware tools设置共享文件夹

步骤说明&#xff1a; 先安装VMware tools&#xff0c;再设置共享文件夹即可。 写在前面&#xff1a; 刚安装虚拟机时&#xff0c;窗口可能显得太小&#xff0c;这是窗口分辨率没有调整导致的。 点击设置->显示->分辨率调整即可 一、安装VMware tools 1.1 点击虚拟机…...

RPA机器人流程自动化专题培训大纲 (针对大学生的版本)

一、课程简介 RPA机器人流程自动化是一种新兴的技术&#xff0c;它通过软件机器人模拟人类操作计算机完成重复性任务&#xff0c;从而实现业务流程的自动化。本课程旨在介绍RPA机器人流程自动化的基本概念、原理和应用&#xff0c;并通过实践案例演示如何应用RPA机器人流程自动…...

数据在内存中的存储——练习4

题目&#xff1a; int main() {char a[1000];int i;for(i0; i<1000; i){a[i] -1-i;}printf("%d",strlen(a));return 0; }思路分析&#xff1a; 已知条件&#xff1a; 通过循环遍历&#xff0c;我们得到的结果是 -1、-2、-3、-4等等。这些是数组内部的存储的元…...

Python 06 之面向对象基础

&#x1f600;前言 在日常编程和软件开发中&#xff0c;我们通常会遇到各种各样的问题&#xff0c;其中很多问题都可以通过面向对象的程序设计方法来解决。面向对象编程不仅可以使代码更加组织化和系统化&#xff0c;而且还可以提高代码的重用性和可维护性。 . 在本教程中&…...

去除pdf/word的水印艺术字

对于pdf中的水印如果无法去除水印&#xff0c;则先另存为word&#xff0c;然后再按下面办法处理即可&#xff1a; 查看宏&#xff0c;创建&#xff1a;删除艺术字 添加内容&#xff1a; Sub 删除艺术字()Dim sh As ShapeFor Each sh In ActiveDocument.ShapesIf sh.Type msoT…...

【Linux】使用 Alist 实现阿里云盘4K播放

一、安装 Alist 官方文档 默认安装在 /opt/alist 中 curl -fsSL "https://alist.nn.ci/v3.sh" | bash -s install自定义安装路径&#xff0c;将安装路径作为第二个参数添加&#xff0c;必须是绝对路径&#xff0c;如果路径以 alist 结尾&#xff0c;则直接安装到给定…...

Gof23设计模式之状态模式

1.概述 【例】通过按钮来控制一个电梯的状态&#xff0c;一个电梯有开门状态&#xff0c;关门状态&#xff0c;停止状态&#xff0c;运行状态。每一种状态改变&#xff0c;都有可能要根据其他状态来更新处理。例如&#xff0c;如果电梯门现在处于运行时状态&#xff0c;就不能…...

如何免费下载RunWayML产生的视频文件

问题&#xff1a; 首先没有下载的按钮。 其次如果直接“视频另存为”菜单&#xff0c;报错。 解决方案&#xff1a; 1&#xff09;复制视频链接。 2&#xff09;新开chrome&#xff0c;在url中粘贴上一步的url路径。 3&#xff09;当看到视频后&#xff0c;在视频上面右键“…...

9.14 C++作业

仿照vector手动实现自己的myVector&#xff0c;最主要实现二倍扩容功能 #include <iostream>using namespace std;template <typename T> class Myvector {T *data; //存储数据的数组int len; //当前数组的长度int mycapa; //容纳数据的总容量public://…...

java关于文件记录篇章之文件夹创建篇

今天&#xff0c;创建一个文件夹目录的时候&#xff0c;创建多级目录的时候发现&#xff0c;自己老是创建失败&#xff0c;但是系统显示文件夹创建成功&#xff0c;但是你去找文件夹的时候&#xff0c;又发现创建失败&#xff0c;这里在我成功之后封装了一个创建文件夹的创建对…...

显示器显示的画面突然偏红色如何解决

显示器显示的画面突然偏红色如何解决 1. 概述2. 解决方法结束语 1. 概述 显示器显示的画面突然偏红色 &#xff0c;使用向日葵远程电脑&#xff0c;看到的画面是正常的&#xff0c;但是显示器上的画面确还是骗红的&#xff0c;这时候就需要看一下是不是开启了系统也夜间模式&a…...

【element-ui】 el-table 表格动态合并相同数据单元格最全教程,可指定列+自定义合并条件,附完整代码

el-table合并单元格 1.固定合并 官方挺提供的合并具体某行列的方法:el-table合并行或列通过给table传入span-method方法可以实现合并行或列,方法的参数是一个对象,里面包含当前行row、当前列column、当前行号rowIndex、当前列号columnIndex四个属性。 该函数可以返回一个包含…...

管理方法论:6. 正视团队冲突——化解危机,长治久安

概念 团队冲突指的是两个或两个以上的团队在目标、利益、认识等方面互不相容或互相排斥&#xff0c;从而产生心理或行为上的矛盾&#xff0c;导致抵触、争执或攻击事件。 参考&#xff1a; https://baike.baidu.com/item/%E5%9B%A2%E9%98%9F%E5%86%B2%E7%AA%81/6747073 htt…...

基于SpringBoot的一套强大后台管理系统

概述 一个功能强大而完善的后台管理系统框架&#xff0c;用户可基于此框架进行二次开发&#xff0c;定制成符合自己的需求的后台管理系统&#xff01; 详细 运行截图&#xff1a; 项目结构&#xff1a; 详细说明&#xff1a; 环境说明&#xff1a; jdk1.8mavenMySQL5.7 项…...

音乐项目后台管理系统出现的问题

1.当对歌手的歌曲进行编辑时候&#xff0c;会把所有的歌曲信息给修改了。 解决方法:修改controller层的中SongController代码中的这一行代码 boolean flag songService.updateById(song); 2.添加歌曲&#xff0c;在弹出框中输入&#xff0c;没有显示。原因&#xff1a;前端页…...

数据结构——图(图的存储及基本操作)

文章目录 前言一、邻接矩阵法&#xff08;顺序存储&#xff09;1.无向图存储邻接矩阵算法2.有向图存储邻接矩阵算法 二、邻接表法(图的链式存储结构)总结 前言 邻接矩阵法(图的顺序存储结构) 1.1 无向图邻接矩阵算法 1.2 有向图邻接矩阵算法邻接表法(图的一种链式存储结构) 一…...

2023年项目管理工具使用趋势分析及预测

随着技术的不断进步以及工作和领导态度的演变&#xff0c;各个行业都在经历着深刻的变革。项目管理领域同样如此&#xff0c;团队项目的技术和人员管理风格及策略正在不断地调整与优化&#xff0c;以适应新冠疫情后所呈现出的新的工作场所格局。在此背景下&#xff0c;以下是我…...

Vue3 实现一个无缝滚动组件(支持鼠标手动滚动)

Vue3 实现一个无缝滚动组件&#xff08;支持鼠标手动滚动&#xff09; 前言 在日常开发中&#xff0c;经常遇到需要支持列表循环滚动展示&#xff0c;特别是在数据化大屏开发中&#xff0c;无缝滚动使用频率更为频繁&#xff0c;在jquery时代&#xff0c;我们常用的无缝滚动组…...

【IP数据报】IP地址和MAC地址的区别

1、用IP地址来标识Internet的主机 在每个IP数据报中&#xff0c;都会携带源IP地址和目标IP地址来标识该IP数据报的源和目的主机。IP数据报在传输过程中&#xff0c;每个中间节点(IP 网关)还需要为其选择从源主机到目的主机的合适的转发路径(即路由)。IP协议可以根据路由选择协…...

高并发笔记

如何设计一个高并发系统&#xff1f;&#xff1a;https://mp.weixin.qq.com/s/yFc-70DEhloWn0G3GDa6Yw 分布式 ID 服务实践&#xff1a;https://mp.weixin.qq.com/s/KAts9Zjj8JpEd0Q6pqLlgQ 一文聊透布隆过滤器&#xff1a;https://mp.weixin.qq.com/s/qJ2fDm1Z57bPSzOBrgiqfg …...

eNSP网络学习

一、eNSP 1.什么是eNSP eNSP(Enterprise Network Simulation Platform)是一款由华为提供的免费的、可扩展的、图形化操作的网络仿真工具平台&#xff0c;主要对企业网络路由器、交换机进行软件仿真&#xff0c;完美呈现真实设备实景&#xff0c;支持大型网络模拟&#xff0c;让…...

做网站找哪个部门/网络营销策划的主要特点

项目问题时有发生&#xff0c;想让项目获得成功&#xff0c;项目经理需要有一个计划来快速有效地应对任何出现的问题。这是最佳实践问题管理过程的一部分&#xff0c;更是良好项目管理的核心本质。 项目问题的四种类型 任何事情都可能成为项目过程中影响项目计划的问题。项目…...

专门做装修的网站/最近的电脑培训学校

给定post请求包体&#xff08;是json的字符串&#xff09; {"A" : 10086,"B" : "请求信息"} 发送HTTP过程 1. 将post请求包体&#xff08;是个json格式的字符串&#xff09;&#xff0c;Marshal成json格式 2. 发送HTTP请求 3. 接收HTTP返回…...

那些公司做网站比较厉害/网上销售渠道

为什么要做持久化存储?持久化存储是将 Redis 存储在内存中的数据存储在硬盘中&#xff0c;实现数据的永久保存。我们都知道 Redis 是一个基于内存的 nosql 数据库&#xff0c;内存存储很容易造成数据的丢失&#xff0c;因为当服务器关机等一些异常情况都会导致存储在内存中的数…...

网站弄论坛形式怎么做/百度官网登录

为什么80%的码农都做不了架构师&#xff1f;>>> 衡量程序的标准 衡量一个程序是否优质&#xff0c;可以从多个角度进行分析。其中&#xff0c;最常见的衡量标准是程序的时间复杂度、空间复杂度&#xff0c;以及代码的可读性、可扩展性。针对程序的时间复杂度和空间…...

晋中营销型网站建设/学习软件的网站

前言 2006初&#xff0c;我接到了公司分配的一个遗留项目&#xff0c;让我负责一个基于C/S的系统的服务器端。其实是系统是基于HTTP协议的&#xff0c;因为负责客户端的同事对于服务器端编程不甚了解&#xff0c;虽然使用PHP对熟悉C&#xff0b;&#xff0b;的他来说是驾轻就熟…...

企业为什么做网站系统/社群营销策略有哪些

目录: 一.网络发展史 1.独立模式 2.网络互联 局域网LAN 1基于网线直连 2基于集线器组建 3基于交换机组建 4基于交换机和路由器组建 广域网WAN 二.网络通信 1认识IP 2认识端口号 3认识协议 4协议分层 5协议图 6协议图讲解 7封装分用 8客户端和服务器 9两台主机的网络通信 10.拓展…...