C语言之三子棋游戏实现篇
目录
主函数test.c
菜单函数
选择实现
游戏函数 (函数调用)
打印棋盘数据
打印展示棋盘
玩家下棋
电脑下棋
判断输赢
循环
test.c总代码
头文件&函数声明game.h
头文件的包含
游戏符号声明
游戏函数声明
game.h总代码
游戏函数game.c
打印棋盘数据InitBoard
打印展示棋盘DisplayBoard
打印数据行
打印分割行
玩家下棋PlayerMove
展示棋盘DisplayBoard
电脑下棋ComputerMove
展示棋盘DisplayBoard
判断输赢IsWin
判断平局IsFull
game.c总代码
拖了许久的三子棋游戏的实现,今天来一步一步的实现三子棋游戏。🙂
主函数test.c
菜单函数
void menu()
{printf("***************************\n");printf("******* 1.Play ********\n");printf("******* 0.over ********\n");printf("***************************\n");
}
选择实现
void menu()
{printf("***************************\n");printf("******* 1.Play ********\n");printf("******* 0.over ********\n");printf("***************************\n");
}
void game()
{printf("开始游戏三子棋\n");
}
int main()
{//打印菜单int input = 0;do{menu();printf("请玩家选择:\n");scanf("%d", &input);switch (input)//分支语句{case 1://玩游戏{game();break;}case 0://结束游戏{printf("游戏结束\n");break;}default:{printf("输入错误,请重新选择\n");break;}}} while (input);
}
以上游戏的菜单和游戏选择我们曾在玩数字游戏中写过,大家可以回顾复习一下。
游戏函数 (函数调用)
打印棋盘数据
- 打印棋盘,我们需要创建二维数组,存放棋盘数据。
char board[ROW][COL];//创建一个二维数组行和列
- 我们需要创建一个函数InitBoard,功能是初始化棋盘数据。
InitBoard(board,ROW,COL);//把数组 数组的行和列都传过去
打印展示棋盘
- 打印棋盘
DisplayBoard(board,ROW,COL);
玩家下棋
PlayerMove(board,ROW,COL);
电脑下棋
ComputerMove(board, ROW, COL);
srand((unsigned int)time(NULL));//产生随机数
//随机数的产生我们在前面猜数字游戏已经讲解过了,忘了的的小朋友可以去看看。
判断输赢
- 玩家赢——函数返回'*'
- 电脑赢——函数返回'#'
- 平局——函数返回'Q'
- 以上三种都跳出了循环,只有游戏继续——返回'C'——继续循环
Iswin(board, ROW, COL);
char ret=0;
ret = Iswin(board, ROW, COL);
if (ret != 'C')
{break;
}
if (ret == '*'){printf("玩家赢\n");}if (ret == '#'){printf("电脑赢\n");}if (ret == 'Q'){printf("平局\n");}
循环
- 每次玩家下棋完展示棋盘和判断输赢,同理电脑下棋完也要展示棋盘和判断输赢。
void game()
{char board[ROW][COL];InitBoard(board, ROW, COL);DisplayBoard(board, ROW, COL);//下棋循环char ret = 0;while (1){PlayerMove(board, ROW, COL);//玩家下棋DisplayBoard(board, ROW, COL);//展示棋盘//判断输赢ret = Iswin(board, ROW, COL);if (ret != 'C'){break;}ComputerMove(board, ROW, COL);//电脑下棋DisplayBoard(board, ROW, COL);//展示棋盘//判断输赢ret = Iswin(board, ROW, COL);if (ret != 'C'){break;}}if (ret == '*'){printf("玩家赢\n");}if (ret == '#'){printf("电脑赢\n");}if (ret == 'Q'){printf("平局\n");}
}
test.c总代码
#define _CRT_SECURE_NO_WARNINGS 1
#include"game.h"
void menu()
{printf("***************************\n");printf("******* 1.Play ********\n");printf("******* 0.over ********\n");printf("***************************\n");
}
//判断输赢
//玩家赢——返回'*'
//电脑赢——返回'#'
//平局——'Q'
// 以上三种都跳出了循环
//游戏继续——'C'
//继续循环
void game()
{char board[ROW][COL];InitBoard(board, ROW, COL);DisplayBoard(board, ROW, COL);//下棋循环char ret = 0;while (1){PlayerMove(board, ROW, COL);//玩家下棋DisplayBoard(board, ROW, COL);//展示棋盘//判断输赢ret = Iswin(board, ROW, COL);if (ret != 'C'){break;}ComputerMove(board, ROW, COL);//电脑下棋DisplayBoard(board, ROW, COL);//展示棋盘//判断输赢ret = Iswin(board, ROW, COL);if (ret != 'C'){break;}}if (ret == '*'){printf("玩家赢\n");}if (ret == '#'){printf("电脑赢\n");}if (ret == 'Q'){printf("平局\n");}
}
int main()
{//打印菜单int input = 0;srand((unsigned int)time(NULL));//产生随机数do{menu();printf("请玩家选择:\n");scanf("%d", &input);switch (input)//分支语句{case 1://玩游戏{printf("开始游戏\n");game();break;}case 0://结束游戏{printf("游戏结束\n");break;}default:{printf("输入错误,请重新选择\n");break;}}} while (input);
}
头文件&函数声明game.h
头文件的包含
在我们写代码的过程中,会调用库函数,需要包含头文件,和声明函数。
所以我们将所有函数声明和头文件放到我们.h 文件中。
当然,在其他.c文件需要使用时,我们只需要包含 我们创造的 头文件"game.h" 即可。
//#include"game.h"
#include<stdio.h>
#include<time.h>
#include<stdlib.h>
游戏符号声明
#define ROW 3
#define COL 3
游戏函数声明
void InitBoard(char board[ROW][COL],int row,int col);//打印棋盘数据
void DisplayBoard(char board[ROW][COL], int row, int col);//打印棋盘
void PlayerMove(char board[ROW][COL], int row, int col);
void ComputerMove(char board[ROW][COL], int row, int col);
char Iswin(char board[ROW][COL], int row, int col);
int IsFull(char board[ROW][COL], int row, int col);
game.h总代码
#define _CRT_SECURE_NO_WARNINGS 1
#pragma once
#include<stdio.h>
#include<time.h>
#include<stdlib.h>
#define ROW 3
#define COL 3
void InitBoard(char board[ROW][COL], int row, int col);
void DisplayBoard(char board[ROW][COL], int row, int col);
void PlayerMove(char board[ROW][COL], int row, int col);
void ComputerMove(char board[ROW][COL], int row, int col);
char Iswin(char board[ROW][COL], int row, int col);
int IsFull(char board[ROW][COL], int row, int col);
游戏函数game.c
分析一下棋盘。
- 棋盘分为 数据行和分割行 。
- 数据行,落子在棋盘上,每一个棋盘上的位置对应二维数组中的一个数组元素。在还未 落子 在棋盘上的时候,最开始棋盘上的数据初始化为空格
- 分割行,有行和列。
分析完棋盘,我们要将棋盘打印出来,也就是把数据行和分割行打印出来,我们需要拆分 。
- 数据行,我们拆分为 空格和 |
- 分割行,我们拆分为 ----和 |
注意:分割行没有最后一列和最后一行,用分支语句来控制。
打印棋盘数据InitBoard
- 我们将数组的参数传递给了函数InitBoard。
- 接下来,利用遍历二维数组元素,把数组中的元素初始化(用赋值运算符)为 空格
- 初始化空格,注意是' '单引号
#include"game.h"
void InitBoard(char board[ROW][COL], int row, int col)
{int i = 0;for (i = 0; i < row; i++){int j = 0;for (j = 0; j < col; j++){board[i][j] = ' ';//初始化为空格//字符单引号!}}
}
打印展示棋盘DisplayBoard
- 注意要换行
- 注意数据行和分割行的空位大小要一致
- 注意使用行和列循环,棋盘被改变格式3*3改为10*10,也不会错乱。
打印数据行
void DisplayBoard(char board[ROW][COL], int row, int col)
{int i = 0;int j = 0;for (i = 0; i < row; i++)//控制行一行一行打印{//打印数据行int j = 0;//每行的元素按列打印for (j = 0; j < col; j++){printf(" ", board[i][j]);//打印数据//初始化为空格//三个空格if (j < col - 1)printf("|");//打印分割线}
打印分割行
//打印分割行printf("\n");if (i < row - 1){int j = 0;for (j = 0; j < col; j++){printf("---");//对应数据行的三个空格if (j < col - 1)printf("|");}}}
}
棋盘效果如下:
玩家下棋PlayerMove
- 注意设置限制条件_不能超出棋盘范围
- 注意棋盘是数组,数组的下标是从0开始的。
- 注意循环,下棋成功break跳出循环。
void PlayerMove(char board[ROW][COL], int row, int col)
{int x = 0;int y = 0;while (1){//先让玩家下棋printf("请输入要下棋的坐标:");scanf("%d %d", &x, &y);//不能超出棋盘范围if (x >= 1 && x <= row && y <= col && y>=1){if (board[x - 1][y - 1] == ' ')//数组下标要从开始{board[x - 1][y - 1] = '*';}else{printf("该坐标已被占用,请输入其他坐标\n");}}else{printf("坐标超出棋盘范围,请重新输入\n");}}
}
展示棋盘DisplayBoard
电脑下棋ComputerMove
- 随机数的产生要掌握🆗
void ComputerMove(char board[ROW][COL], int row, int col)
{printf("电脑下棋\n");int x = 0;int y = 0;while (1){x = rand() % row;y = rand() % col;//产生随机值if (board[x][y] == ' '){board[x][y] = '#';break;}}
}
展示棋盘DisplayBoard
判断输赢IsWin
- 玩家赢——函数返回'*'
- 电脑赢——函数返回'#'
- 平局——函数返回'Q'
- 以上三种都跳出了循环,只有游戏继续——返回'C'——继续循环
产生以上的结果的条件,我们来分析以下:
char Iswin(char board[ROW][COL], int row, int col)
{int i = 0;for (i = 0; i < row; i++)//先一行判断{if (board[i][0] == board[i][1] && board[i][1] == board[i][2] && board[i][1] != ' ')//循环1{return board[i][1];}if (board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[1][i] != ' ')//循环2{return board[1][i];}if (board[0][0] == board[1][1] && board[1][1] == board[2][2] && board[1][1] != ' ')//循环3{return board[1][1];}if (board[2][2] == board[1][1] && board[1][1] == board[0][2] && board[1][1] != ' '){return board[1][1];}if (IsFull(board, row, col))//返回1真执行,返回0假不执行{return 'Q';}//如果以上情况均不是return 'C';}
}
判断平局IsFull
if (IsFull(board, row, col))//返回1真执行,返回0假不执行
{return 'Q';
}
int IsFull(char board[ROW][COL], int row, int col)
{int i = 0;int j = 0;for (i = 0; i < row; i++){for (j = 0; j < col; j++){if (board[i][j] == ' ')return 0;//有空位不执行}}return 1;
}
game.c总代码
#define _CRT_SECURE_NO_WARNINGS 1
#include"game.h"
void InitBoard(char board[ROW][COL], int row, int col)
{int i = 0;for (i = 0; i < row; i++){int j = 0;for (j = 0; j < col; j++){board[i][j] = ' ';//初始化为空格}}
}void DisplayBoard(char board[ROW][COL], int row, int col)
{int i = 0;int j = 0;for (i = 0; i < row; i++)//控制行一行一行打印{//打印数据行int j = 0;//每行的元素按列打印for (j = 0; j < col; j++){printf(" %c ", board[i][j]);//打印数据//初始化为空格if (j < col - 1)printf("|");//打印分割线}//打印分割行printf("\n");if (i < row - 1){int j = 0;for (j = 0; j < col; j++){printf("---");if (j < col - 1)printf("|");}}printf("\n");}
}void PlayerMove(char board[ROW][COL], int row, int col)
{int x = 0;int y = 0;while (1){//先让玩家下棋printf("请输入要下棋的坐标:");scanf("%d %d", &x, &y);//不能超出棋盘范围if (x >= 1 && x <= row && y <= col && y>=1){if (board[x - 1][y - 1] == ' ')//数组下标要从开始{board[x - 1][y - 1] = '*';break;}else{printf("该坐标已被占用,请输入其他坐标\n");}}else{printf("坐标超出棋盘范围,请重新输入\n");}}
}void ComputerMove(char board[ROW][COL], int row, int col)
{printf("电脑下棋\n");int x = 0;int y = 0;while (1){x = rand() % row;y = rand() % col;//产生随机值if (board[x][y] == ' '){board[x][y] = '#';break;}}
}char Iswin(char board[ROW][COL], int row, int col)
{int i = 0;for (i = 0; i < row; i++)//先一行判断{if (board[i][0] == board[i][1] && board[i][1] == board[i][2] && board[i][1] != ' ')//循环1{return board[i][1];}if (board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[1][i] != ' ')//循环2{return board[1][i];}if (board[0][0] == board[1][1] && board[1][1] == board[2][2] && board[1][1] != ' ')//循环3{return board[1][1];}if (board[2][2] == board[1][1] && board[1][1] == board[0][2] && board[1][1] != ' '){return board[1][1];}if (IsFull(board, row, col))//返回1真执行,返回0假不执行{return 'Q';}//如果以上情况均不是return 'C';}
}int IsFull(char board[ROW][COL], int row, int col)
{int i = 0;int j = 0;for (i = 0; i < row; i++){for (j = 0; j < col; j++){if (board[i][j] == ' ')return 0;//有空位不执行}}return 1;
}
✔✔✔✔✔最后,感谢大家的阅读,如有不足和错误,欢迎指正。
代码---------→【gitee:https://gitee.com/TSQXG】
联系---------→【邮箱:2784139418@qq.cqq
相关文章:
![](https://img-blog.csdnimg.cn/86e27eb4a569461e94fc5f8e987a6e74.png)
C语言之三子棋游戏实现篇
目录 主函数test.c 菜单函数 选择实现 游戏函数 (函数调用) 打印棋盘数据 打印展示棋盘 玩家下棋 电脑下棋 判断输赢 循环 test.c总代码 头文件&函数声明game.h 头文件的包含 游戏符号声明 游戏函数声明 game.h总代码 游戏函数ga…...
![](https://img-blog.csdnimg.cn/8d20b6da88784b28b00f5fc8b1c17c03.png)
jupyter notebook 插件nbextensions的安装
安装步骤: 1、打开 jupyter notebook,新建一个 python 文件; 2、 分别输入以下代码,然后运行,出现 warning 不影响使用,如果出现 errors,则说明下载有问题: !python -m pip install…...
![](https://img-blog.csdnimg.cn/a95ffd1345154d7aabf4b602f921af81.jpeg)
Spring boot 集成单元测试
1.引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency> 2. 3.编写测试类 package com.enterprise;import com.enterpr…...
![](https://img-blog.csdnimg.cn/91bb406d6c934f03b15aed4f013f37d0.png)
基于C++的QT实现贪吃蛇小游戏
文章目录: 一:效果演示 二:实现思路 三:代码实现 widget.h widget.cpp main.cpp 一:效果演示 效果图◕‿◕✌✌✌ 代码下载 二:实现思路 通过按键控制蛇的移动,每吃一个商品蛇身就会加长…...
![](https://img-blog.csdnimg.cn/3d2b2a73154844e188314ae3f95efcd2.png)
Spring Boot整合RabbitMQ之路由模式(Direct)
RabbitMQ中的路由模式(Direct模式)应该是在实际工作中运用的比较多的一种模式了,这个模式和发布与订阅模式的区别在于路由模式需要有一个routingKey,在配置上,交换机类型需要注入DirectExchange类型的交换机bean对象。…...
![](https://img-blog.csdnimg.cn/c6f6aef22ef44e01971d53ccb5035933.png)
行式存储与列式存储
1.概述 数据处理大致可分为两大类,联机事务处理OLTP(on-line transaction processing) 和联机分析处理OLAP(on-line analytical processing)。 OLTP是传统关系型数据库的主要应用,用来执行一些基本的、日常的事务处理,比如数据库记录的增、删…...
![](https://img-blog.csdnimg.cn/f82dae9051b84f9182142a2e2fdbd43d.png)
windows上sqlserver的ldf日志文件和数据mdf文件分别放到不同的磁盘
之前我的windows上已安装好了sqlserver2017,有一个名为TestDb的数据库。ldf文件和mdf文件都一起放在D:\Database目录下。现在需要把ldf日志文件到E盘的database目录下。 重要的事情先说三遍 先停止网关(例如nginx)并备份数据库 先停止网关&am…...
![](https://img-blog.csdnimg.cn/ea85217c0ec94f19833ae0c5bc440491.png)
vue3+uni——watch监听props中的数据(组件参数接收与传递defineProps、defineEmits)
案例说明 A页面引用的子组件B A页面 <template><view>//引用组件<serviceOrder change"change" :list"list" :current"type"></serviceOrder></view> </template><script setup>import serviceOrd…...
![](https://img-blog.csdnimg.cn/9356956979e340629d088506eab7f2d7.png)
mybatis与spring集成与spring aop集成pagehelper插件
Mybatis与Spring的集成 Mybatis是一款轻量级的ORM框架,而Spring是一个全栈式的框架,二者的结合可以让我们更加高效地进行数据持久化操作。 Mybatis与Spring的集成主要有两种方式:使用Spring的Mybatis支持和使用Mybatis的Spring支持。 使用…...
![](https://img-blog.csdnimg.cn/06d5ee5c64634e77a626fdff33de60f5.png)
Mybatis基础
...
![](https://img-blog.csdnimg.cn/2315b42685404be9a697926669b6841f.png)
TypeScript-- 配置Typescript环境(1)ts 转js,tsc --watch 实时编译
文章目录 安装Typescript判断是否有运行权限编写第一Typescript文件手动编译Ts文件转Js文件实时编译 安装Typescript npm install -g typescript 判断是否有运行权限 命令行运行 tsc -v 遇到了权限问题 用管理员打开window自带的powershell 运行如下指令即可: Set-…...
![](https://img-blog.csdnimg.cn/7ab73817f6af4f93861debd9e89cd5c7.png)
Dockerfile快速搭建自己专属的LAMP环境,生成镜像lamp:v1.1,并推送到私有仓库
环境: CentOS 7 Linux 3.10.0-1160.el7.x86_64 具体要求如下: (1)基于centos:6基础镜像; (2)指定作者信息; (3)安装httpd、mysql、mysql-server、php、ph…...
![](https://img-blog.csdnimg.cn/96bb68b4447043549f2034a21d099195.png)
Lottery抽奖项目学习第二章第一节:环境、配置、规范
Lottery抽奖项目学习第二章第一节:环境、配置、规范 环境、配置、规范 下面以DDD架构和设计模式落地实战的方式,进行讲解和实现分布式抽奖系统的代码开发,那么这里会涉及到很多DDD的设计思路和设计模式应用,以及互联网大厂开发中…...
![](https://www.ngui.cc/images/no-images.jpg)
OpenCV之reshape函数
函数原型: /** brief Changes the shape and/or the number of channels of a 2D matrix without copying the data.The method makes a new matrix header for \*this elements. The new matrix may have a different sizeand/or different number of channels. A…...
![](https://img-blog.csdnimg.cn/59c2d80e01f34f3ab7563f0736a77b88.png)
【JavaEE】Spring事务-@Transactional参数介绍-事务的隔离级别以及传播机制
【JavaEE】Spring事务(2) 文章目录 【JavaEE】Spring事务(2)1. Transactional 参数介绍1.1 value 和 transactionManager1.2 timeout1.3 readOnly1.4 后面四个1.5 isolation 与 propagation 2. Spring 事务隔离级别 - isolation2.…...
![](https://img-blog.csdnimg.cn/abd2740a8e2a4243bb89257d4b295562.png)
微信小程序canvas type=2d生成海报保存到相册、文字换行溢出显示...、文字删除线、分享面板
一、简介 做个简单的生成二维码海报分享,我做的时候也找简单的方法看能不能实现页面直接截图那种生成图片,原生小程序不支持,不多介绍下面有全部代码有注释、参数自行替换运行看看,还有需要优化的地方,有问题可以咨询…...
![](https://www.ngui.cc/images/no-images.jpg)
C++卷积神经网络
C卷积神经网络 #include"TP_NNW.h" #include<iostream> #pragma warning(disable:4996) using namespace std; using namespace mnist;float* SGD(Weight* W1, Weight& W5, Weight& Wo, float** X) {Vector2 ve(28, 28);float* temp new float[10];V…...
![](https://www.ngui.cc/images/no-images.jpg)
go 读取yaml映射到struct
安装 go get gopkg.in/yaml.v3创建yaml Mysql:Host: 192.168.214.134Port: 3306UserName: wwPassword: wwDatabase: go_dbCharset: utf8mb4ParseTime: trueLoc: LocalListValue:- haha- test- vv JWTSecret: nidaye定义结构体 type Mysql struct {Host string yaml:&…...
![](https://img-blog.csdnimg.cn/ffb9f9704f294f078b159cbd82e14f35.png)
Redis 10 大数据类型
1. which 10 1. redis字符串 2. redis 列表 3. redis哈希表 4. redis集合 5. redis有序集合 6. redis地理空间 7. redis基数统计 8. redis位图 9. redis位域 10. redis流 2. 获取redis常见操作指令 官网英文:https://redis.io/commands 官网中文:https:/…...
![](https://img-blog.csdnimg.cn/c8c956391e154e949f11f36ffea9b5a0.jpeg#pic_center)
优化生产流程:数字化工厂中的OPC UA分布式IO模块应用
背景 近年来,为了提升在全球范围内的竞争力,制造企业希望自己工厂的机器之间协同性更强,自动化设备采集到的数据能够发挥更大的价值,越来越多的传统型工业制造企业开始加入数字化工厂建设的行列,实现智能制造。 数字化…...
![](https://img-blog.csdnimg.cn/d0d24f215ae94a1997f40078025308d7.png)
Elasticsearch(十四)搜索---搜索匹配功能⑤--全文搜索
一、前言 不同于之前的term。terms等结构化查询,全文搜索首先对查询词进行分析,然后根据查询词的分词结果构建查询。这里所说的全文指的是文本类型数据(text类型),默认的数据形式是人类的自然语言,如对话内容、图书名…...
![](https://img-blog.csdnimg.cn/65365c23dd4c4e499028802bac6bb0d4.jpeg)
已解决Gradle错误:“Unable to load class ‘org.gradle.api.plugins.MavenPlugin‘”
🌷🍁 博主猫头虎 带您 Go to New World.✨🍁 🦄 博客首页——猫头虎的博客🎐 🐳《面试题大全专栏》 文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺 &a…...
![](https://img-blog.csdnimg.cn/25a11fac244e4efc87f09748c02cf1dc.png)
windows中安装sqlite
1. 下载文件 官网下载地址:https://www.sqlite.org/download.html 下载sqlite-dll-win64-x64-3430000.zip和sqlite-tools-win32-x86-3430000.zip文件(32位系统下载sqlite-dll-win32-x86-3430000.zip)。 2. 安装过程 解压文件 解压上一步…...
![](https://www.ngui.cc/images/no-images.jpg)
前端面试:【系统设计与架构】前端架构模式的演进
前端架构模式在现代Web开发中扮演着关键角色,它们帮助我们组织和管理前端应用的复杂性。本文将介绍一些常见的前端架构模式,包括MVC、MVVM、Flux和Redux,以及它们的演进和应用。 1. MVC(Model-View-Controller)&#x…...
![](https://www.ngui.cc/images/no-images.jpg)
【CSS】em单位的理解
1、em单位的定义 MDN的解释:它是相对于父元素的字体大小的一个单位。 例如:父元素font-size:16px;子元素的font-size:2em(也就是32px) 注:有一个误区,虽然他是一个相对…...
![](https://www.learnfk.com/guide/images/wuya.png)
无涯教程-Python机器学习 - Based on human supervision函数
Python机器学习 中的 Based on human s - 无涯教程网无涯教程网提供https://www.learnfk.com/python-machine-learning/machine-learning-with-python-based-on-human-supervision.html...
![](https://img-blog.csdnimg.cn/e2fcce2177d44bbc9e616fc1439870d9.png)
【滑动窗口】leetcode209:长度最小的子数组
一.题目描述 长度最小的子数组 二.思路分析 题目要求:找出长度最小的符合要求的连续子数组,这个要求就是子数组的元素之和大于等于target。 如何确定一个连续的子数组?确定它的左右边界即可。如此一来,我们最先想到的就是暴力枚…...
![](https://www.ngui.cc/images/no-images.jpg)
C++ STL unordered_map
map hashmap 文章目录 Map、HashMap概念map、hashmap 的区别引用头文件初始化赋值unordered_map 自定义键值类型unordered_map 的 value 自定义数据类型遍历常用方法插入查找 key修改 value删除元素清空元素 unordered_map 中每一个元素都是一个 key-value 对,数据…...
![](https://img-blog.csdnimg.cn/861bd5dca2774e14a8bd8fdcd51e9b54.png)
全流程R语言Meta分析核心技术应用
Meta分析是针对某一科研问题,根据明确的搜索策略、选择筛选文献标准、采用严格的评价方法,对来源不同的研究成果进行收集、合并及定量统计分析的方法,最早出现于“循证医学”,现已广泛应用于农林生态,资源环境等方面。…...
![](https://img-blog.csdnimg.cn/img_convert/04875e5751783e5afef1dfaec1df8735.png)
Go并发可视化解释 - Select语句
昨天,我发布了一篇文章,用可视化的方式解释了Golang中通道(Channel)的工作原理。如果你对通道的理解仍然存在困难,最好呢请在阅读本文之前先查看那篇文章。作为一个快速的复习:Partier、Candier 和 Stringe…...
![](/images/no-images.jpg)
ih5 做视频网站/贵阳网站建设制作
??正想点击一个在线同学的头像,电话铃响了,一看号码,生疏的数字串。按键接听,虽然不大熟习的男中音,所传来的欢乐而冲动的音符却使我捕到了久违的欢喜信息!那语气,企业宣传片 ,只能是亲朋好友…...
![](https://www.oschina.net/img/hot3.png)
企业网站用户群/百度seo搜索营销新视角
为什么80%的码农都做不了架构师?>>> 有时候不想放弃jpa持久化的便利性,又不想因此牺牲了查询的灵活性,所以列举两种jpa下的灵活查询方式。 单表查询指定Entity中的部分字段 这块比较简单,只需要定义一个存放部分属性的…...
![](http://www.officezhushou.com/uploads/allimg/130803/2-130P3235320S0.jpg)
广州互联网公司排行榜/兰州网络推广优化怎样
Word2010会自动产生编号,相当方便。可是也有一些用户觉得这个功能“自作聪明”想取消它,那么可按如下方法操作。 方法1、产生自动编号后,再按一次<Enter>键。 方法2、产生自动编号后,按下<CtrlZ>组合键。 方法3、如果…...
![](https://yqfile.alicdn.com/img_405b18b4b6584ae338e0f6ecaf736533.gif)
自己做网站升seo/如何快速推广自己的品牌
由于人员的不段增加varchar(5000)已经不能满足需求,现在的方案是把字段类型由varchar改为text 1 --修改短信人员字段 2 alter table T_BAS_SendMessage alter column [Content] text 3 alter table T_BAS_SendMessage alter column ReceiveInsideName text 4 alter …...
![](/images/no-images.jpg)
网站域名空间5个G的多少钱/美国婚恋网站排名
文章目录一、前言二、问题分隔线三、真相四、参考一、前言 在使用git这个多人协作的代码版本控制工具时,为了避免每次提交修改代码时,一些预期外的无用文件的改动同时被提交并加入版本控制,需要将一些和代码无关的无用文件排除在版本控制外&…...
![](https://images2015.cnblogs.com/blog/589642/201706/589642-20170618024909071-1692365378.png)
深圳网站建设 沙漠风/武汉seo首页优化技巧
前言 Hello,开始回归开始每周更新一到两篇博客,本节我们回归下EF Core基础,来讲述EF Core中到底是如何映射的,废话少说,我们开始。 One-Many Relationship(一对多关系) 首先我们从最简单的一对多…...