12 c++版本的坦克大战

前言

呵呵 这大概是 大学里面的 c++ 贪吃蛇了吧 

有一些 面向对象的理解, 但是不多 

这里 具体的实现 就不赘述, 仅仅是 发一下代码 以及 具体的使用 

 

 

坦克大战

#include<iostream>
#include<windows.h>
#include<conio.h>
#include<ctime>
#include<string>
#include<list>
using namespace std;
#define N 4
class Tank_War;
void set_pos(int x, int y);
class Object
{	
protected:int x, y;int dir;int life;public:Object() : x(0), y(0), dir(-1),life(1)	{}Object(int x, int y, int dir, int life) : x(x), y(y), dir(dir), life(life) {}	 void move();void paint()  {	}void reduce_blood()	{	life -= 1; 	}void increase_blood()	{	life += 1; 	}bool is_failure();virtual void print(){cout<<x<<"--"<<y<<"=="<<life<<"--"<<endl;}
};class Missile : public Object
{
public:Missile() : Object() {}Missile(int x, int y, int dir, int life) : Object(x, y, dir, life) {}bool move();void paint(string icon);int get_x()const	{	return x;	}int get_y()const	{	return y;	}void set_info(int x, int y, int dir) {	this -> x = x; this -> y = y; this -> dir = dir;	};bool operator==(const Missile&_x){return (x==_x.x && y==_x.y&&dir==_x.dir);		}		//list中remove是需要重载==
};class Tank : public Object
{
private:int pre_dir;list<Missile> missile_list;public:Tank() : Object(), pre_dir(-1) {}Tank(int x, int y, int dir, int life) : Object(x, y, dir,life) {pre_dir = dir;};void del_before_move();void move(Tank_War &game, string name);void paint(string icon);int get_x()	const	{	return x;	}int get_y()	const	{	return y;	}int get_dir()const	{	return dir;	}void set_dir(int dir){	pre_dir = this -> dir;	this -> dir = dir;	}void set_location(int x, int y){	this -> x = x;	this -> y = y;	}void emission_missile();void missile_move();void check_missile(Tank_War &game, string name);bool check_missile_strike(Missile& missile, Tank& tank);
//	bool check_is_right(int x, int y, int dir);int distance_squre(int x_1, int y_1, int x_2, int y_2);int distance_squre(Tank& tank_2);bool operator==(const Tank&_x){return (x==_x.x && y==_x.y&&dir==_x.dir);		}
};class Tank_War
{
private:Tank lead;list<Tank> enemy_list;int tot;int grade;bool over;public:Tank_War():lead(28, 21, -1, 4), grade(0), tot(0), over(false) {};int game();void game_over()	{	over = true;	}int draw_menu();void draw_game_interface();Tank* get_lead()	{	return &lead;	}list<Tank>::iterator get_enemy_list_begin()	{	return enemy_list.begin();	}list<Tank>::iterator get_enemy_list_end()	{	return enemy_list.end();	}Tank* create_enemy();void enemy_move();
//	bool check_is_right(int x, int y, int dir);bool can_move(Tank &tank, string name);bool can_move(Tank& x, Tank& y);void check_missile(string name);void supply_enemy();int get_random_direction();list<Tank>::iterator remove_from_enemy_list(list<Tank>::iterator it)	{	return enemy_list.erase(it);		}void reduce_tot()	{	tot--;	}void increase_grade()	{	grade+=5;set_pos(68, 3);cout<<grade;	}
};int main()
{Tank_War g;g.game();system("pause");return 0;
}int Tank_War::game()
{bool is_move = true;int speed = draw_menu();system("cls");draw_game_interface();supply_enemy();while(!over){if(!lead.is_failure()){if(tot<N) 	supply_enemy();if(GetAsyncKeyState(VK_UP))	lead.set_dir(-1);else if(GetAsyncKeyState(VK_DOWN))	lead.set_dir(1);else if(GetAsyncKeyState(VK_LEFT))	lead.set_dir(-2);else if(GetAsyncKeyState(VK_RIGHT))	lead.set_dir(2);else is_move = false;if(is_move) lead.move(*this, "lead");	enemy_move();if(GetAsyncKeyState(VK_RETURN))	lead.emission_missile();	if(enemy_list.size() != 0){check_missile("lead");check_missile("enemy");}		}is_move = true;lead.missile_move();Sleep(100);}return 0;
}void set_pos(int x, int y)
{HANDLE cursor = GetStdHandle(STD_OUTPUT_HANDLE);COORD position = {x, y};SetConsoleCursorPosition(cursor, position);
}void draw_rect(int x_1, int y_1, int x_2, int y_2, string icon)
{if(x_1 > x_2)	swap(x_1, x_2);if(y_1 > y_2)	swap(y_1, y_2);int n_1 = y_2 - y_1 + 1;int n_2 = (x_2 - x_1)/icon.size() + 1;for(int i=0; i<n_1; i++){set_pos(x_1, y_1+i);for(int j=0; j<n_2; j++)cout<<icon;}
} int Tank_War::draw_menu()
{int speed = 0;draw_rect(0, 3, 79, 3, "-");draw_rect(0, 5, 79, 5, "-");set_pos(25, 2);cout<<"welcome to airplane war games ";set_pos(25, 4);cout<<"↑ up   ↓ down   enter confirm";set_pos(20, 10);cout<<"1.easy		easy mode enemy move slow";set_pos(20, 14);cout<<"2.difficult		difficult mode enemy move fast";set_pos(20, 20);cout<<"made by He Xiong .   begin at 2014_01_08";draw_rect(0, 19, 79, 19, "-");draw_rect(0, 22, 79, 22, "-");set_pos(18, 10);cout<<"->";int y = 10;while(true){if(GetAsyncKeyState(VK_UP) || GetAsyncKeyState(VK_DOWN)){if(y == 10){set_pos(18, y);		cout<<"  ";y = 14;set_pos(18, y);		cout<<"->";speed = 1;}else if(y == 14){set_pos(18, y);		cout<<"  ";y = 10;set_pos(18, y);		cout<<"->";speed = 0;}}else if(GetAsyncKeyState(VK_RETURN))		break;Sleep(200);}return speed;
}void Tank_War::draw_game_interface()
{draw_rect(0, 0, 78, 0, "◆");draw_rect(0, 23, 78, 23, "◆");draw_rect(0, 1, 0, 22, "◆");draw_rect(58, 1, 58, 22, "◆");draw_rect(78, 1, 78, 22, "◆");int x = 62;set_pos(x, 3);		cout<<"GRADE:0";set_pos(x, 5);		cout<<"LEVEL:1";set_pos(62, 7);		cout<<"↑ UP";set_pos(x, 9);		cout<<"↓ down";set_pos(x, 11);		cout<<"← left";set_pos(x, 13);		cout<<"→ right";set_pos(x, 17);		cout<<"life:■■";set_pos(x+5, 18);	cout<<"■■";lead.set_location(28, 10);lead.paint("■");set_pos(0, 0);
}Tank* Tank_War::create_enemy()
{int n = 0, k = 0;int x = 0, y = 0, dir = 0;Tank *p = NULL;srand((unsigned)time(NULL));while(k != 4){n = rand()%2;if(n%2 == 0){x = 4;			n = rand()%2;if(n%2 == 0)	y = 2;else			y = 21;}else{x = 54;			n = rand()%2;if(n%2 == 0)	y = 2;else			y = 21;}dir = get_random_direction();p = new Tank(x, y, dir, 1);enemy_list.push_back(*p);if(can_move(*p, "enemy")){	break;	}else	{	enemy_list.pop_back();	delete p;	p = NULL;	}k++;}return p;
}
/*
bool Tank::check_is_right(int x, int y, int dir)
{if(distance_squre(x, y, this -> x, this -> y) > 9)return true;else return false;
}
*//*
bool Tank_War::check_is_right(int x, int y, int dir)
{int flag = 0;if(!lead.check_is_right(x, y, dir))	++flag;list<Tank>::iterator it = NULL;for(it=enemy_list.begin(); it!=enemy_list.end(); ++it)if(!it -> check_is_right(x, y, dir))	++flag;if(flag == 0)	return true;else			return false;
}
*/
void Tank_War::supply_enemy()
{int n = N - tot;Tank *p = NULL;for(int i=0; i<n; i++){if((p = create_enemy()) != NULL){tot++;			p -> paint("■");delete p;		p = NULL;}}
}void Missile::paint(string icon)
{set_pos(x, y);	cout<<icon;
}void Tank::paint(string icon)
{draw_rect(x-2, y, x+2, y, icon);draw_rect(x, y-1, x, y+1, icon);if((dir+2)%2 == 0){set_pos(x-dir, y-1);	cout<<icon;set_pos(x-dir, y+1);	cout<<icon;}else if((dir+2)%2 == 1){set_pos(x-2, y-dir);	cout<<icon;set_pos(x+2, y-dir);	cout<<icon;}/*					//不是很好,前面两点的会闪set_pos(x-2, y-1);cout<<"■■■";set_pos(x-2, y);cout<<"■■■";set_pos(x-2, y+1);cout<<"■■■";if((dir+2)%2 == 0){set_pos(x+dir, y-1);	cout<<"  ";set_pos(x+dir, y+1);	cout<<"  ";draw_rect(x-dir, y-1, x-dir, y+1);}else if((dir+2)%2 == 1){set_pos(x-1, y+dir);	cout<<"  ";set_pos(x+1, y+dir);	cout<<"  ";draw_rect(x-2, y-dir, x+2, y-dir);}
*/
}bool Missile::move()
{if(x>2 && x<56 && y>1 && y <22){if((dir+2)%2 == 0){set_pos(x, y);	cout<<"  ";x += dir;		paint("●");}else if((dir+2)%2 == 1){set_pos(x, y);	cout<<"  ";y += dir;		paint("●");}return true;}else{if(x==0 || x==58 || y==0 || y==23)	;else{	set_pos(x, y);	cout<<"  ";}return false;}
}void Tank::move(Tank_War& game, string name)
{if(x>2 && x<56 && y>1 && y <22)if((dir+2)%2 == 0){Tank p(x+dir, y, dir, 1);if(x+dir>2 && x+dir<56){if(game.can_move(p, name)){//draw_rect(x-dir, y-1, x-dir, y+1, "  ");//draw_rect(x+dir, y, x+dir, y, "  ");	//为了解决在角落是的BUGdel_before_move();x+=dir;paint("■");}}else {if(pre_dir > 0)	draw_rect(x+dir, y-1, x+dir, y-1, "  ");else	draw_rect(x+dir, y+1, x+dir, y+1, "  ");paint("■");}}else{Tank p(x, y+dir, dir, 1);if(y+dir>1 && y+dir<22){if(game.can_move(p, name)){del_before_move();y+=dir;paint("■");}}else {if(pre_dir > 0)	draw_rect(x-2, y+dir, x-2, y+dir, "  ");else	draw_rect(x+2, y+dir, x+2, y+dir, "  ");paint("■");}}}void Tank::del_before_move()
{if(pre_dir == dir)	if((dir + 2) % 2 == 0)	draw_rect(x-dir, y-1, x-dir, y+1, "  ");else	draw_rect(x-2 , y-dir, x+2, y-dir, "  ");else if(pre_dir == -dir)	if((dir + 2) % 2 == 0)	draw_rect(x+pre_dir, y, x+pre_dir, y, "  ");else	draw_rect(x , y+pre_dir, x, y+pre_dir, "  ");else if(pre_dir == 2/dir)	if((dir + 2) % 2 == 0)	draw_rect(x-dir, y, x-dir, y-pre_dir, "  ");else	draw_rect(x, y-dir, x-pre_dir, y-dir, "  ");elseif((dir + 2) % 2 == 0)	draw_rect(x-dir, y, x-dir, y-pre_dir, "  ");else	draw_rect(x, y-dir, x-pre_dir, y-dir, "  ");
}bool Tank_War::can_move(Tank& tank, string name)
{if(name == "lead"){list<Tank>::iterator it = NULL;if(enemy_list.size() != 0){for(it=enemy_list.begin(); it!=enemy_list.end(); it++){if(!can_move(*it, tank))	return false;}}}else{int flag = 0;if(!can_move(lead, tank))	return false;list<Tank>::iterator it = NULL;if(enemy_list.size() != 0){for(it=enemy_list.begin(); it!=enemy_list.end(); it++){	if(!can_move(*it, tank)) flag++;/*if(tank == *it)	{if(flag)	flag = false;else		return false;}else{if(!can_move(tank,tank.get_dir() , *it))	return false;}*/}if(flag!=1) return false;else return true;}}return true;
}bool Tank_War::can_move(Tank& tank_1, Tank& tank_2)
{int x_1 = 0, x_2 = 0, y_1 = 0, y_2 = 0;int dis = tank_1.distance_squre(tank_2);if(dis > 8)	return true;else if(dis == 8){if((tank_1.get_dir()+2)%2 == 0){if(tank_1.get_dir() > 0)	{x_1 = tank_1.get_x();	x_2 = tank_2.get_x();y_1 = tank_1.get_y();	y_2 = tank_2.get_y();}else{x_1 = tank_2.get_x();	x_2 = tank_1.get_x();y_1 = tank_2.get_y();	y_2 = tank_1.get_y();}if(x_1 > x_2){if(y_1 > y_2){if(tank_2.get_dir() == tank_1.get_dir() || tank_2.get_dir() == 2/tank_1.get_dir())	return true;else	return false;}else{if(tank_2.get_dir() == tank_1.get_dir() || tank_2.get_dir() == -2/tank_1.get_dir())	return true;else	return false;}}else		return true;}else{if(tank_1.get_dir() > 0)	{x_1 = tank_1.get_x();	x_2 = tank_2.get_x();y_1 = tank_1.get_y();	y_2 = tank_2.get_y();}else{x_1 = tank_2.get_x();	x_2 = tank_1.get_x();y_1 = tank_2.get_y();	y_2 = tank_1.get_y();}if(y_1 > y_2){if(x_1 > x_2){if(tank_2.get_dir() == tank_1.get_dir() || tank_2.get_dir() == 2/tank_1.get_dir())	return true;else	return false;}else{if(tank_2.get_dir() == tank_1.get_dir() || tank_2.get_dir() == -2/tank_1.get_dir())	return true;else	return false;}}else		return true;}}else if(dis == 5)	{	//static int d=0;d++;set_pos(20,20+d);cout<<dis<<"D"<<endl;if((tank_1.get_dir()+2)%2 == 0){if(tank_1.get_dir() > 0)	{x_1 = tank_2.get_x();	x_2 = tank_1.get_x();y_1 = tank_2.get_y();	y_2 = tank_1.get_y();}else{x_1 = tank_1.get_x();	x_2 = tank_2.get_x();y_1 = tank_1.get_y();	y_2 = tank_2.get_y();}if(x_1 > x_2){if(y_1 > y_2){if(tank_2.get_dir() == -tank_1.get_dir() || tank_2.get_dir() == -2/tank_1.get_dir())	return true;else	return false;}else{if(tank_2.get_dir() == -tank_1.get_dir() || tank_2.get_dir() == -2/tank_1.get_dir())	return true;else	return false;}}else		return false;}else{if(tank_1.get_dir() < 0)	{x_1 = tank_1.get_x();	x_2 = tank_2.get_x();y_1 = tank_1.get_y();	y_2 = tank_2.get_y();}else{x_1 = tank_2.get_x();	x_2 = tank_1.get_x();y_1 = tank_2.get_y();	y_2 = tank_1.get_y();}if(y_1 > y_2){if(x_1 > x_2){if(tank_2.get_dir() == -tank_1.get_dir() || tank_2.get_dir() == -2/tank_1.get_dir())	return true;else	return false;}else{if(tank_2.get_dir() == -tank_1.get_dir() || tank_2.get_dir() == 2/tank_1.get_dir())	return true;else	return false;}}else		return false;}}else		return false;
}bool Object::is_failure()
{if(life != 0)	return false;else			return true;
}void Tank::emission_missile()
{Missile p;if((dir+2)%2 == 0)p.set_info(x+2*dir, y, dir);else if((dir+2)%2 == 1)p.set_info(x, y+2*dir, dir);missile_list.push_back(p);if(p.get_x()==0 || p.get_x()==58 || p.get_y()==0 || p.get_y()==23)	;else			p.paint("■");Sleep(100);
}void Tank::missile_move()
{list<Missile>::iterator it = NULL;if(missile_list.size() != 0)			//这里一定要判空for(it=missile_list.begin(); it!=missile_list.end(); it++){if(!it -> move())it = missile_list.erase(it);		//删除此步后当前迭代器会“失效”}
}void Tank_War::check_missile(string name)
{if(name == "lead")lead.check_missile(*this, "lead");else{list<Tank>::iterator it = NULL;for(it = enemy_list.begin(); it != enemy_list.end(); it++)it -> check_missile(*this, "enemy");}
}void Tank::check_missile(Tank_War &game, string name)
{list<Missile>::iterator it_1 = NULL;list<Tank>::iterator it_2 = NULL;if(name == "lead"){if(missile_list.size() != 0)for(it_1=missile_list.begin(); it_1!= missile_list.end(); it_1++){for(it_2=game.get_enemy_list_begin(); it_2!=game.get_enemy_list_end(); it_2++)if(it_1 != missile_list.end())if(check_missile_strike(*it_1, *it_2))	{it_1 = missile_list.erase(it_1);if(it_2 -> is_failure()){game.increase_grade();it_2 -> paint("  ");it_2 = game.remove_from_enemy_list(it_2);game.reduce_tot();}}	}}else{if(missile_list.size() != 0){if(it_1 != missile_list.end())for(it_1=missile_list.begin(); it_1!= missile_list.end(); it_1++)if(check_missile_strike(*it_1, *(game.get_lead())))	{it_1 = missile_list.erase(it_1);if(game.get_lead() -> is_failure())		game.game_over();else {game.get_lead() -> paint("  ");game.get_lead() -> set_location(28, 10);game.get_lead() -> paint("■");}}if(it_1 != missile_list.end())for(it_1=missile_list.begin(); it_1!= missile_list.end(); it_1++){for(it_2=game.get_enemy_list_begin(); it_2!=game.get_enemy_list_end(); it_2++)if(check_missile_strike(*it_1, *it_2))	{it_1 = missile_list.erase(it_1);it_2 -> increase_blood();}}}}
}bool Tank::check_missile_strike(Missile& missile, Tank& tank)
{int dis = 0;if((dis = distance_squre(missile.get_x(), missile.get_y(), tank.get_x(), tank.get_y())) <= 2){if(dis == 2){}else{missile.reduce_blood();tank.reduce_blood();missile.paint("  ");return true;}}return false;
}void Tank_War::enemy_move()
{int n = 0;srand((unsigned)time(NULL));list<Tank>::iterator it = NULL;if(enemy_list.size() != 0){for(it=enemy_list.begin(); it != enemy_list.end(); it++){it -> missile_move();n = rand()%3;if(n == 0)if(can_move(*it, "enemy")){n = get_random_direction();it -> set_dir(n);it->move(*this, "enemy");}n = rand()%8;if(n == 0)	it -> emission_missile();}}
}int Tank::distance_squre(int x_1, int y_1, int x_2, int y_2)
{return (x_2 - x_1) * (x_2 - x_1) + (y_2 - y_1) * (y_2 - y_1);
}int Tank::distance_squre(Tank& tank_2)
{return distance_squre(x/2, y, tank_2.get_x()/2, tank_2.get_y());
}int Tank_War::get_random_direction()
{int n = 0;srand((unsigned)time(NULL));if((n = rand()%4) < 2)		n -= 2;else		n -= 1;return n;
}

 

 

程序截图

首页

6e5ec33a8cee48ec9a8b3815a83072c7.png

 

 

程序执行界面

e0bd744179ac47c89c6b96f0c347b0ba.png

 

 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/314342.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

jvm(JVM快速入门、stack栈、堆、GC垃圾回收、Arthas)

文章目录 1. JVM快速入门1.1. 结构图1.2. 类加载器ClassLoader1.3. 执行引擎Execution Engine1.4. 本地接口Native Interface1.5. Native Method Stack1.6. PC寄存器(程序计数器)1.7. Method Area方法区 2. stack栈3. 堆3.1. 堆体系概述3.1.1. 新生区3.1.2. 老年代3.1.3. 永久代…

分类预测 | Matlab实现CNN-GRU-SAM-Attention卷积门控循环单元融合空间注意力机制的数据分类预测

分类预测 | Matlab实现CNN-GRU-SAM-Attention卷积门控循环单元融合空间注意力机制的数据分类预测 目录 分类预测 | Matlab实现CNN-GRU-SAM-Attention卷积门控循环单元融合空间注意力机制的数据分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 1.Matlab实现CNN-GRU…

Visual Studio 对 C++ 头文件和模块的支持

在 C 编程领域&#xff0c;头文件和模块的管理有时候确实比较令人头疼。但是&#xff0c;有许多工具和功能可以简化此过程&#xff0c;提高效率并减少出错的可能性。下面是我们为 C 头文件和模块提供的几种工具的介绍。 构建明细 通过菜单栏 Build > Run Build Insights&a…

基于Rust的多线程 Web 服务器

构建多线程 Web 服务器 在 socket 上监听 TCP 连接解析少量的 HTTP 请求创建一个合适的 HTTP 响应使用线程池改进服务器的吞吐量优雅的停机和清理注意&#xff1a;并不是最佳实践 创建项目 ~/rust ➜ cargo new helloCreated binary (application) hello package~/rust ➜ma…

maven-依赖管理

依赖配置 https://mvnrepository.com/?__cf_chl_rt_tkvRzDsumjmJ_HF95MK4otu9XluVRHGqAY5Wv4UQYETR8-1714103058-0.0.1.1-1557 <dependencies><dependency><groupId></groupId><artifactId></artifactId><version></version>…

Day4 商品管理

Day4 商品管理 这里会总结构建项目过程中遇到的问题&#xff0c;以及一些个人思考&#xff01;&#xff01; 学习方法&#xff1a; 1 github源码 文档 官网 2 内容复现 &#xff0c;实际操作 项目源码同步更新到github 欢迎大家star~ 后期会更新并上传前端项目 编写品牌服务 …

Java集合相关的List、Set、Map基础知识

目录 一、集合介绍 二、List 三、Map HashMap的数据结构 如何理解红黑树 四、set 一、集合介绍 在Java中&#xff0c;集合是一种用于存储对象的数据结构&#xff0c;它提供了一种更加灵活和强大的方式来处理和操作数据。Java集合框架提供了一系列接口和类&#xff0c;用…

表格的单元格合并和表头的合并——vxe-table

vxe-table的官网&#xff1a;https://vxetable.cn/#/table/advanced/mergeCell在你的项目中下载安装完成后&#xff0c;先在main.js文件中引入&#xff1a; import VXETable from vxe-table import vxe-table/lib/style.css Vue.use(VXETable)一、单元格合并 效果图&#xff…

Linux驱动开发——(七)Linux阻塞和非阻塞IO

目录 一、阻塞和非阻塞IO简介 二、等待队列 2.1 等待队列头 2.2 等待队列项 2.3 将队列项添加/移除等待队列头 2.4 等待唤醒 2.5 等待事件 三、轮询 四、驱动代码 4.1 阻塞IO 4.2 非阻塞IO 一、阻塞和非阻塞IO简介 IO指的是Input/Output&#xff0c;也就是输入/输…

JavaWeb--06Vue组件库Element

Element 1 Element组件的快速入门1.1 Table表格 1 Element组件的快速入门 https://element.eleme.cn/#/zh-CN Element是饿了么团队开发的 接下来我们来学习一下ElementUI的常用组件&#xff0c;对于组件的学习比较简单&#xff0c;我们只需要参考官方提供的代码&#xff0c;然…

SSH新功能揭秘:远程工作提升指南【AI写作】

首先&#xff0c;这篇文章是基于笔尖AI写作进行文章创作的&#xff0c;喜欢的宝子&#xff0c;也可以去体验下&#xff0c;解放双手&#xff0c;上班直接摸鱼~ 按照惯例&#xff0c;先介绍下这款笔尖AI写作&#xff0c;宝子也可以直接下滑跳过看正文~ 笔尖Ai写作&#xff1a;…

同态加密原理解析

目录 1.数学介绍2.使用多项式环进行加密2.1 私钥和公钥的产生2.2 加密2.3 解密 3.同态计算3.1 同态加法3.2 同态乘法 1.数学介绍 同态加密方案基于一个难以计算的问题Ring Learning with Errorsred。这些方案中的数据在加密和未加密时都用多项式表示。 这里举一个简单的多项式…

什么是IIoT?

什么是IIoT? IIoT&#xff0c;即工业物联网&#xff08;Industrial Internet of Things&#xff09;&#xff0c;是指将物联网技术应用到工业领域&#xff0c;通过微型低成本传感器、高带宽无线网络等技术手段&#xff0c;实现工业设备、系统和服务的互联互通&#xff0c;从而…

ChatGPT/GLM API使用

模型幻觉问题 在自然语言处理领域&#xff0c;幻觉&#xff08;Hallucination&#xff09;被定义为生成的内容与提供的源内容无关或不忠实&#xff0c;具体而言&#xff0c;是一种虚假的感知&#xff0c;但在表面上却似乎是真实的。产生背景 检索增强生成&#xff08;RAG&…

基于MLP算法实现交通流量预测(Pytorch版)

在海量的城市数据中&#xff0c;交通流量数据无疑是揭示城市运行脉络、洞察出行规律的关键要素之一。实时且精准的交通流量预测不仅能为交通规划者提供科学决策依据&#xff0c;助力提升道路使用效率、缓解交通拥堵&#xff0c;还能为公众出行提供参考&#xff0c;实现个性化导…

算法 || 二分查找

目录 二分查找 在排序数组中查找元素的第一个和最后一个位置 搜索插入位置 一个数组经过划分后具有二段性的都可以用二分查找 二分查找 704. 二分查找 - 力扣&#xff08;LeetCode&#xff09; ​ 暴力解法&#xff1a;直接遍历数组&#xff0c;找到 target 便返回下标&am…

原型链prototype、__proto、constructor的那些问题整理

再了解原型链之前,我们先来看看构造函数和实例对象的打印结构 - 函数 这里我们定义一个构造函数Fn,然后打印它的结构吧 function Fn(){} console.dir(Fn)控制台得到结构 从上面结构我们能看的出来,函数有两种原型,一种是作为函数特有的原型:prototype,另一种是作为对象的__…

低代码技术的全面应用:加速创新、降低成本

引言 在当今数字化转型的时代&#xff0c;企业和组织面临着不断增长的应用程序需求&#xff0c;以支持其业务运营和创新。然而&#xff0c;传统的软件开发方法通常需要大量的时间、资源和专业技能&#xff0c;限制了企业快速响应市场变化和业务需求的能力。在这样的背景下&…

chrome浏览器安装elasticsearch的head可视化插件

head插件简介 elasticsearch-head被称为是弹性搜索集群的web前端&#xff0c;head插件主要是用来和elastic Cluster交互的Web前端 head插件历史 elasticsearch-head插件在0.x-2.x版本的时候是集成在elasticsearch内的&#xff0c;由elasticsearch的bin/elasticsearch-plugin…

区块链 | OpenSea 相关论文:Toward Achieving Anonymous NFT Trading(一)

​ &#x1f951;原文&#xff1a; Toward Achieving Anonymous NFT Trading &#x1f951;写在前面&#xff1a; 本文对实体的介绍基于论文提出的方案&#xff0c;而非基于 OpenSea 实际采用的方案。 其实右图中的 Alice 也是用了代理的&#xff0c;不过作者没有画出来。 正文…