Android开发简单的2048游戏

2023-05-16

作为一名android渣渣第一次用android写了个简单的小游戏还是模仿网上的视频写的,,哎,,


视频教程链接


写在前面:这里我用的IDE是eclipse,所以对与 Android studio 的来说可能会有点那个,,,

但是主要的代码应该没问题的哈,,


界面和实现的逻辑:    

1,activity_main.xml

这是游戏的主界面(layout),游戏界面 整体采用线性布局,然后嵌套一个计分器面板也是线性布局,

中间用了两个textView一个显示Score字体一个显示分数然后下面的游戏界面用个类绑定,类继承

格子布局,然后游戏的主要布局就在那个类中实现

2,card.java 类

这是2048游戏中的抽象出来的卡片,这里我们来定义一些卡片的性质和一些接口供我们只用,我们用

个lable组件来表示卡片,大小为32*32显示的数字为num,如果是0就是空 ,颜色会根据数字的不同而

不同,布局用layoutparms 来控制,边距为10,即格子与格子之间的距离为10

3,GameView.java 类

这里是游戏界面的布局和游戏逻辑的控制,首先通过构造函数来初始化游戏initGameView()这里面设置

界面布局的列为4列,背景颜色为0xffbbada0然后 写个监听事件,监听触摸事件,setOnTouchListener,

首先这里我们定义startX,startY,offsetX,offsetY,当触摸时startX = even.getX(),startY = even.getY()当触

摸结束时,offsetX = even.getX ()- startX offsetY = even.getY ()- startY  有了这些变量我们就可以判断

手指滑动的方向了,如果如果abs(offsetX)>abs(offsetY)则滑动的方向定义为水平移动,然后我们定义

如果offset X<-5则为向左,这里取了个相对值,其他的同理可得,然后我们重载 onSizeChanged方法,

即,如果窗口大改变是就执行这个方法,一开始打开时窗口大小方式改变,这里要在配置文件里配置

屏幕为竖屏,然后就执行这个方法,所以我们可以在这里记录卡片的长宽 = (min(w,h)  -10)/4,然后

addCard(); startGame();在addCard中我们首先定义了个card的二维数组来保存界面上的4*4的卡片,

然后初始值为0,这里就初始了界面的4*4的卡片,然后就是随机添加两个卡片这里写个随机生成卡片

的方法,首先我们用个集合把所有空的卡片的点存进去,然后从中随机生成个,然后在随机生成个

数,这里2:4 = 9:1 ,所以我们就可以判断生成0-1的数与0.1比较,然后就实现了这个1:9,接下来就

是移动的操作,我们分别写四个方法实现上下左右的操作,对于一种操作我们用三层循环去遍历,

这里我们假设向右,我们外层循环遍历x,y从1-4,然后内存循环遍历4到y+1,即每一行向右移动,

我们先从最右边找,看它的左边是否有卡片,然后还要判断是否相同,相同就把数字相加存在最右

边这个卡片,不相同就把卡片移动到它的左边,然后向左移动一格(如果当前有)如果出现过有效

的移动就要在随机一个卡片,最后判断结束就是没有空的卡片并且没有相邻且数字相同的卡片


上面就是我简单的介绍我的代码的三个主要的代码类,其中有些模糊希望理解,表达不是很清晰,主要还是看代码吧!



MainActivity.java

package com.example.game2048;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.widget.TextView;

public class MainActivity extends Activity {

	
	public MainActivity() {
		// TODO Auto-generated constructor stub
		setMainActivity(this);
	}
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		tvScore = (TextView) findViewById(R.id.tvScore);
		
		
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		// Inflate the menu; this adds items to the action bar if it is present.
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}
	
	
	public void clearScore(){
		score = 0;
		showScore();
	}
	
	public void showScore(){
		tvScore.setText(score+"");
	}
	
	public void addScore(int s){
		score+=s;
		showScore();
	}
	
	public static MainActivity getMainActivity() {
		return mainActivity;
	}

	public static void setMainActivity(MainActivity mainActivity) {
		MainActivity.mainActivity = mainActivity;
	}
	private int score = 0;
	private  TextView tvScore;
	private static MainActivity mainActivity = null;
	

}



activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:orientation="vertical"
    tools:context=".MainActivity" >
    
    
    
    <LinearLayout 
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">
        
        <TextView 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/score"/>
        <TextView 
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/tvScore"/>
        
        
    </LinearLayout>
    
    <com.example.game2048.GameView
        android:layout_width="fill_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:id="@+id/gameView">
        
    </com.example.game2048.GameView>

</LinearLayout>




card.java

package com.example.game2048;

import android.R.color;
import android.content.Context;
import android.content.pm.LabeledIntent;
import android.graphics.Color;
import android.view.Gravity;
import android.widget.FrameLayout;
import android.widget.TextView;

public class Card extends FrameLayout {

	
	// 记录卡片的颜色
	
	private int [] cardColor = new int[30]; 
	
	
	//初始化卡片的颜色
	public void setColor(){
		cardColor[0] =Color.BLUE;
		cardColor[1] = Color.CYAN;
		cardColor[8] = Color.DKGRAY;
		cardColor[5] = Color.GRAY;
		cardColor[4] = Color.GREEN;
		cardColor[3] = Color.RED;
		cardColor[6] = Color.LTGRAY;
		cardColor[7] = Color.MAGENTA;
		cardColor[2]= Color.YELLOW;
		cardColor[9] = Color.WHITE;
		cardColor[10] = Color.TRANSPARENT;
	}
	
	
	//构造方法
	public Card(Context context) {
		super(context);
		
		setColor();
		lable = new TextView(getContext());
		lable.setTextSize(32);				//设置大小
		lable.setBackgroundColor(0x33ffffff);   //背景颜色
		lable.setGravity(Gravity.CENTER);		//布局为居中

		LayoutParams lp = new LayoutParams(-1,-1);
		lp.setMargins(10, 10, 0, 0);		//边距为10
		addView(lable, lp);
		setNum(0);
		
	}
	private int num = 0;
	
	
	//获取数字
	public int getNum() {
		return num;
	}

	//设置数字
	public void setNum(int num) {
		this.num = num;
		if(num<=0){
			lable.setBackgroundColor(0x33ffffff);
			lable.setText("");
		}else {
			//取log得到x设置颜色
			int x =(int) (Math.log((double)num));
			x%=11;
			lable.setBackgroundColor(cardColor[x]);
			lable.setText(num+"");
		}
		
	}

	//卡片的lable组件
	private TextView lable;
	
	
	//判断是否相等
	public boolean equals(Card o) {
		// TODO Auto-generated method stub
		return num==o.getNum();
	}
	

}



GameView.java


package com.example.game2048;

import java.util.ArrayList;
import java.util.List;

import android.R.bool;
import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.graphics.Point;
import android.provider.ContactsContract.CommonDataKinds.Event;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
import android.widget.GridLayout;

public class GameView extends GridLayout {

	//构造方法
	
	
	public GameView(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
		// TODO Auto-generated constructor stub
		initGameView();
	}

	public GameView(Context context, AttributeSet attrs) {
		super(context, attrs);
		// TODO Auto-generated constructor stub
		initGameView();
	}

	public GameView(Context context) {
		super(context);
		// TODO Auto-generated constructor stub
		initGameView();
	}

	
	//初始化游戏
	private void initGameView(){
		
		setColumnCount(4);   //设置列为4
		setBackgroundColor(0xffbbada0);  //设置背景色
		
		//监听触摸事件
		setOnTouchListener(new OnTouchListener() {
			
			private float startX,startY,offsetX,offsetY;   //四个变量记录初始位置和偏移量
			
			@Override
			public boolean onTouch(View arg0, MotionEvent even) {
				// TODO Auto-generated method stub
				switch(even.getAction()){
				case MotionEvent.ACTION_DOWN:    //记录初始位置
					startX = even.getX();
					startY = even.getY();
					break;
				case MotionEvent.ACTION_UP:      //记录偏移量
					offsetX = even.getX()-startX;
					offsetY = even.getY() -startY;
					
					
					if(Math.abs(offsetX)>Math.abs(offsetY)){   //X的偏移量大于Y的偏移量
						if(offsetX<-5){
							swipeLeft();		//向左的操作
						}else {
							swipeRight();		//向右的操作
						}
					}else {
						if(offsetY<-5){
							swipeUp();			//向上的操作
						}else{
							swipeDown();		//向下的操作
						}
					}
					
					break;
				
				}
				
				return true;
			}
		});
	}
	
	
	//重载方法,窗口大小改变使执行
	@Override
	protected void onSizeChanged(int w, int h, int oldw, int oldh) {
		// TODO Auto-generated method stub
		super.onSizeChanged(w, h, oldw, oldh);
		//记录卡片的大小
		int cardWidth = (Math.min(w, h)-10)/4;
		//添加卡片
		addCards(cardWidth, cardWidth);
		//开始游戏
		startGame();
		
	}
	
	
	//添加卡片
	private void addCards(int cardWidth,int cardHeight){
		Card card;
		//4*4
		for(int i=0;i<4;i++){
			for(int j=0;j<4;j++){
				card = new Card(getContext());   //初始化卡片对象
				card.setNum(0);					//初始值为0
				addView(card,cardWidth,cardHeight);//添加
				cardsMap[i][j] = card;				//将卡片与cardMap绑定
			}
		}
	}
	
	//添加随机卡片
	private void addRandomNum(){
		
		//记录空卡片的点的集合
		emptyPoints.clear();
		for(int i=0;i<4;i++){
			for(int j=0;j<4;j++){
				if(cardsMap[j][i].getNum()<=0){
					emptyPoints.add(new Point(j,i));  //添加所有空卡片
				}
			}
		}
		Point point = emptyPoints.remove((int)(Math.random()*emptyPoints.size()));  //从空卡片中随机一个卡片
		cardsMap[point.x][point.y].setNum(Math.random()>0.1?2:4);				//随机生成一个数 2:4 = 1:9
	}
	
	//开始游戏方法
	private void startGame(){
		//分数清零
		MainActivity.getMainActivity().clearScore();
		for(int i=0;i<4;i++){
			for(int j=0;j<4;j++){
				cardsMap[j][i].setNum(0);  //初始化为0
			}
		}
		//随机生成两个卡片
		addRandomNum();
		addRandomNum();
	}
	
	
	//向左移动的方法
	private void swipeLeft(){
		boolean flag = false;
		for(int x = 0;x<4;x++){
			for(int y = 0;y<4;y++){
				for(int y1 = y+1;y1<4;y1++){
					if(cardsMap[x][y1].getNum()>0){	//如果枚举位置有卡片
						if(cardsMap[x][y].getNum()<=0){		//如果当前位置没有卡片
							cardsMap[x][y].setNum(cardsMap[x][y1].getNum());	//直接移动到当前位置
							cardsMap[x][y1].setNum(0);
							y--;	//向前移动
							flag = true;
						}else if(cardsMap[x][y].equals(cardsMap[x][y1])){		//如果当前位置有卡片且相等
							cardsMap[x][y].setNum(cardsMap[x][y].getNum()*2);	//覆盖当前卡片并且数组相加
							cardsMap[x][y1].setNum(0);
							MainActivity.getMainActivity().addScore(cardsMap[x][y].getNum());  //分数增加
							flag = true;
						}
						
						break;
					}
				}
			}
		}
		if(flag){
			//如果有有效移动则随机一张卡片并且判断是否结束
			addRandomNum();
			checkComplete();
		}
	}
	
	//同上 向右移动的操作
	private void swipeRight(){
		boolean flag = false;
		for(int x = 0;x<4;x++){
			for(int y = 3;y>=0;y--){
				for(int y1 = y-1;y1>=0;y1--){
					if(cardsMap[x][y1].getNum()>0){
						if(cardsMap[x][y].getNum()<=0){
							cardsMap[x][y].setNum(cardsMap[x][y1].getNum());
							cardsMap[x][y1].setNum(0);
							y++;
							flag = true;
						}else if(cardsMap[x][y].equals(cardsMap[x][y1])){
							cardsMap[x][y].setNum(cardsMap[x][y].getNum()*2);
							cardsMap[x][y1].setNum(0);
							MainActivity.getMainActivity().addScore(cardsMap[x][y].getNum());
							flag = true;
						}
						
						break;
					}
				}
			}
		}
		if(flag){
			addRandomNum();
			checkComplete();
		}
	}
	//同上,向上移动的操作
	private void swipeUp(){
		boolean flag = false;
		for(int y = 0;y<4;y++){
			for(int x = 0;x<4;x++){
				for(int x1 = x+1;x1<4;x1++){
					if(cardsMap[x1][y].getNum()>0){
						if(cardsMap[x][y].getNum()<=0){
							cardsMap[x][y].setNum(cardsMap[x1][y].getNum());
							cardsMap[x1][y].setNum(0);
							x--;
							flag = true;
						}else if(cardsMap[x][y].equals(cardsMap[x1][y])){
							cardsMap[x][y].setNum(cardsMap[x][y].getNum()*2);
							cardsMap[x1][y].setNum(0);
							MainActivity.getMainActivity().addScore(cardsMap[x][y].getNum());
							flag = true;
						}
						
						break;
					}
				}
			}
		}
		if(flag){
			addRandomNum();
			checkComplete();
		}
		
	}
	//同上,向下移动的操作
	private void swipeDown(){
		
		boolean flag = false;
		
		for(int y = 0;y<4;y++){
			for(int x = 3;x>=0;x--){
				for(int x1 = x-1;x1>=0;x1--){
					if(cardsMap[x1][y].getNum()>0){
						if(cardsMap[x][y].getNum()<=0){
							cardsMap[x][y].setNum(cardsMap[x1][y].getNum());
							cardsMap[x1][y].setNum(0);
							x++;
							 flag = true;
						}else if(cardsMap[x][y].equals(cardsMap[x1][y])){
							cardsMap[x][y].setNum(cardsMap[x][y].getNum()*2);
							cardsMap[x1][y].setNum(0);
							MainActivity.getMainActivity().addScore(cardsMap[x][y].getNum());
							flag = true;
						}
						break;
					}
				}
			}
		}
		
		if(flag){
			addRandomNum();
			checkComplete();
		}
	}
	
	
	//判断是否结束游戏
	private void checkComplete(){
		boolean complete = true;
		All:
		for(int x = 0;x<4;x++){
			for(int y=0;y<4;y++){
				//判断有空或上下左右有相同的卡片则没结束
				if(cardsMap[x][y].getNum()==0||
				  (x-1>=0&&cardsMap[x][y].equals(cardsMap[x-1][y]))||
				  (x+1<4&&cardsMap[x][y].equals(cardsMap[x+1][y]))||
				  (y-1>=0&&cardsMap[x][y].equals(cardsMap[x][y-1]))||
				  (y+1<4&&cardsMap[x][y].equals(cardsMap[x][y+1]))){
					complete = false;
					break All;
				}
			}
		}
		//游戏结束
		if(complete){
			new AlertDialog.Builder(getContext()).setTitle("你好").setMessage("游戏结束!").setPositiveButton("重来", new DialogInterface.OnClickListener() {

				
				//重新开始游戏
				@Override
				public void onClick(DialogInterface arg0, int arg1) {
					// TODO Auto-generated method stub
					startGame();
				}
			}).show();
		}
		
	}
	
	//记录4*4卡片的数组
	private Card [][] cardsMap = new Card[4][4];
	//记录空卡片的集合
	private List<Point> emptyPoints = new ArrayList<Point>();
	
}



本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Android开发简单的2048游戏 的相关文章

  • php网站压测(ab)

    一般来说核心页面都需要进行压测 xff0c 特别是秒杀页面 xff0c 从而知道网站的承受能力 xff0c 方便暴露一些问题 xff0c 更好的把控网站 压测工具有很多种 xff0c 最简单 方便的可以使用ApacheBench xff0c
  • CSV文件读取 C++版本

    代码 span class token comment 创建结构体 xff0c 把读取数据可以放入结构体成员中 span span class token keyword struct span span class token class
  • 四种常见的 POST 提交数据方式

    HTTP 1 1 协议规定的 HTTP 请求方法有 OPTIONS GET HEAD POST PUT DELETE TRACE CONNECT 这几种 其中 POST 一般用来向服务端提交数据 xff0c 本文主要讨论 POST 提交数据
  • json_decode

    json 61 34 34 errorno 34 0 34 errormsg 34 34 可以 34 34 data 34 34 guid 34 34 5762340 34 34 username 34 34 wiu370468 34 34
  • csv乱码处理

    handle 61 fopen 34 war csv 34 34 r 34 row 61 1 while data 61 fgetcsv handle 1000 34 34 data 61 eval 39 return 39 iconv 3
  • OR和AND关键字一起使用的情况

    OR和AND关键字一起使用的情况 OR关键字和AND关键字 xff0c 可以一起使用 xff0c 需要注意 xff0c AND的优先级高于OR 因此 xff0c 当两者一起使用时 xff0c 应该先运算AND两边的条件表达式 xff0c 再
  • Ubuntu cron 定时执行任务

    cron xff0c 是一个Linux定时执行工具 xff0c 可以在无需人工干预的情况下运行作业 1 关于crontab 在Ubuntu server 下 xff0c cron是被默认安装并启动的 通过 etc crontab文件 xff
  • Linux服务器上监控网络带宽的18个常用命令

    本文介绍了一些可以用来监控网络使用情况的Linux命令行工具 这些工具可以监控通过网络接口传输的数据 xff0c 并测量目前哪些数据所传输的速度 入站流量和出站流量分开来显示 一些命令可以显示单个进程所使用的带宽 这样一来 xff0c 用户
  • Linux系统使用iftop查看带宽占用情况

    Linux系统下如果服务器带宽跑满了 xff0c 查看跟哪个ip通信占用带宽比较多 xff0c 可以通过iftop命令进行查询 xff0c 使用方法如下 xff1a 1 安装方法 软件官网地址 xff1a http www ex parro
  • linux基础命令

    1 curl amp wget 使用curl或wget命令 xff0c 不用离开终端就可以下载文件 如你用curl xff0c 键入curl O后面跟一个文件路径 wget则不需要任何选项 下载的文件在当前目录 代码如下 curl O we
  • find_in_set

    1 in查询相当于多个or条件的叠加 xff0c 例如 xff1a select from user where user id in 1 2 3 等效于 select from user where user id 61 1 or use
  • 集成Cortex-M0内核-- Integration and Implementation Manual手册学习

    根据使用场景 xff0c 配置并集成一个Cortex M0的内核 xff0c 暂时不涉及的实现的部分 目录 阅读手册 Chapter1 Introduction 1 1 About the processor 1 2 About integ
  • 在NVIDIA NX 配置OpenCV多版本冲突和解决的总结

    Nvidia Jetson NX 环境 直接刷JetPack5 1的镜像 xff0c 会得到如下环境 Ubuntu20 04cuda11 4TensorRT8 4cudnn8 4opencv4 5 4 而且这些源一般是从nv xxxx等源下
  • 一款入门级的飞控CC3D(一)

    很多在校的朋友想自己动手做一款旋翼无人机 xff0c 但是零件采购下来要花费不少大洋 xff0c 装配完成后又需要进行软件硬件调试 所以很多想做极客的梦就扼杀在摇篮里 本期我将开始更新一款入门级的飞控CC3D 首先 xff0c 放上CC3D
  • 朱刘算法(Directed Minimum Spanning Tree/Directed MST/Minimum Arborescence/Optimum Branchings)

    概念 最小树形图 xff1a 有向图所分离出的有向生成树 亦称为最小树形图 xff0c 其应满足以下条件 xff1a 1 恰好有一个入度为0的点 xff0c 称为根结点 2 其他结点的入度均为1 3 可以从根结点到达其他结点 既然要找最小生
  • 仿真复现文章推荐

    以下学长推荐的文章 xff1a 人脸识别 xff1a SphereFace Deep Hypersphere Embedding for Face Recognition 手势姿态 xff1a OpenPose 3D人脸建模 xff1a L
  • 查看GPU显存 使用率

    watch n 0 2 nvidia smi 主要关注GPU Util Memory Usage 0 2表示每隔0 2秒刷新一次终端的显示结果 上面的表格中 xff1a 第一栏的Fan xff1a N A是风扇转速 xff0c 从0到100
  • scipy.ndimage.zoom

    最近邻 选择离它所映射到的位置最近的输入像素的灰度值为插值结果 最临近插值 3X3 的256级灰度图 xff0c 也就是高为3个象素 xff0c 宽也是3个象素的图像 xff0c 每个象素的取值可以是 0 xff0d 255 xff0c 代
  • torch.manual_seed()

    torch manual seed args seed 为CPU设置种子用于生成随机数 xff0c 以使得结果是确定的 if args cuda torch cuda manual seed args seed 为当前GPU设置随机种子 x
  • python torch.optim.SGD

    torch optim sgd学习参数 torch入门笔记14 Torch中optim的sgd Stochastic gradient descent 方法的实现细节 pytorch中使用torch optim优化神经网络以及优化器的选择

随机推荐

  • python zero_grad()

    有两种方式直接把模型的参数梯度设成0 xff1a model span class hljs preprocessor zero span grad optimizer span class hljs preprocessor zero s
  • torch.topk

    torch kthvalue input k dim 61 None keepdim 61 False out 61 None gt Tensor LongTensor k xff1a 第k个最小元素 返回第k个最小元素 input k d
  • torch.normal()

    torch normal means std out 61 None 返回一个张量 xff0c 包含从给定参数means std的离散正态分布中抽取随机数 均值means是一个张量 xff0c 包含每个输出元素相关的正态分布的均值 std是
  • 台式机ubuntu18.04 x86_64 简单ROS版本安装及其他库编译

    本教程是用于只安装ros melodic ros base的情况下 xff0c 为了避免安装opencv3 2 xff0c 而只保留一个opencv3 4 10 xff0c 而一步步安装rqt xff0c cv bridge xff0c r
  • ubuntu 当前文件夹 文件个数

    ls l grep 34 34 wc l
  • python [:,::-1]

    In span class hljs number 33 span t 61 np array span class hljs string 1 2 3 4 5 6 7 8 9 span In span class hljs number
  • numpy.floor

    numpy floor x out 61 None where 61 True casting 61 39 same kind 39 order 61 39 K 39 dtype 61 None subok 61 True signatur
  • Perfdog玩转内存泄漏

    背景交代 最近QC同学在跑游戏的过程中发现玩的时间久了游戏会发生闪退 xff0c 经过和开发人员讨论后又搜集了一些信息 xff0c 最后排除了功能性bug的原因 一 判断是否是内存泄露 拿到真机 xff0c USB连接 xff0c 杀掉多余
  • LCD1602知识详解(很详尽的)

    1602液晶知识详解 xff1a 1 1602液晶基础 VSS xff1a 电源地信号引脚 xff1b VDD xff1a 电源信号引脚 xff1b VEE xff1a 液晶对比度调节引脚 xff0c 接0 5V以调节液晶的显示对比度 xf
  • 如何学习嵌入式软件

    什么是嵌入式 xff1f 嵌入式分为广义和狭义两种 广义的嵌入式就是片上系统 system on a chip xff0c 包括单片机 PSOC NIOS Microblaze等 而狭义的嵌入式就是ARM9 cortex A8等特定的跑操作
  • Raspberry Pi 4B 通过 MAVROS 实现从地面站远程连接飞控板

    Raspberry Pi 4B 通过 MAVROS 实现从地面站远程连接飞控板 0x00 为 RPi 刷写系统0x01 启动 Ubuntu0x02 使用 SSH 连接至 RPi0x03 更换软件源0x04 安装桌面环境 xff08 可选 x
  • LeetCode-T97-交错字符串(interleaving-string)

    题目 原题链接 题目描述 xff1a 给定三个字符串 s1 s2 s3 验证 s3 是否是由 s1 和 s2 交错组成的 样例 case1 输入 s1 61 aabcc s2 61 dbbca s3 61 aadbbcbcac 输出 tru
  • LeetCode-T167-两数之和 II - 输入有序数组(two-sum-ii-input-array-is-sorted)

    题目 原题链接 题目描述 xff1a 给定一个已按照升序排列 的有序数组 xff0c 找到两个数使得它们相加之和等于目标数 函数应该返回这两个下标值 index1 和 index2 xff0c 其中 index1 必须小于 index2 说
  • LeetCode-T95-不同的二叉搜索树 II(unique-binary-search-trees-ii)

    题目 题目链接 题目描述 给定一个整数 n xff0c 生成所有由 1 n 为节点所组成的 二叉搜索树 样例 case1 输入 xff1a 3 输出 xff1a 1 null 3 2 3 2 null 1 3 1 null null 2 2
  • 主从机时间同步

    安装 服务器和客户端都安装 sudo apt get install ntpsudo apt get install ntpdate 服务器端 配置文件设置 运行sudo vim etc ntp conf在文件末尾加入如下几行代码 rest
  • 判断两条线段是否相交(三种算法)

    转载于 xff1a http blog csdn net rickliuxiao article details 6259322 算法1 xff1a cpp view plain copy alg 1 struct Point double
  • 朱、刘算法:求最小树形图权值个人理解+个人详解【最小树形图模板】

    什么是最小树形图 xff1f 相信大家如果会过来看这篇文章 xff0c 想必也应该对最小生成树有所了解的 xff0c 最小生成树求的是无向图的一颗生成树的最小权值 我们的最小树形图就是来解决一个有向图的一颗生成树的最小权值 xff0c 对于
  • Floyd最小环算法

    问题描述 xff1a 给你一张无向图 xff0c 定义环为从i出发到达j然后从j返回i并且所有点都只经过一次 xff08 最少为3个点 xff09 xff0c 求所有环当中经过路径最小的环 算法描述 xff1a 首先容易想到的是暴力来枚举环
  • O(1)快速乘

    求两个数相乘超过long long取摸的快速运算O 1 inline long long multi long long x long long y long long mod long long tmp 61 x y long long
  • Android开发简单的2048游戏

    作为一名android渣渣第一次用android写了个简单的小游戏还是模仿网上的视频写的 xff0c xff0c 哎 xff0c xff0c 视频教程链接 写在前面 xff1a 这里我用的IDE是eclipse xff0c 所以对与 And