Python迷宫生成器

🚀 优质资源分享 🚀

学习路线指引(点击解锁)知识定位人群定位
🧡 Python实战微信订餐小程序 🧡进阶级本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。
💛Python量化交易实战💛入门级手把手带你打造一个易扩展、更安全、效率更高的量化交易系统

作为一项古老的智力游戏,千百年来迷宫都散发着迷人的魅力。但是,手工设计迷宫费时又耗(脑)力,于是,我们有必要制作一个程序:迷宫生成器……

好吧,我编不下去了。但是,从上面的文字中,我们可以看出,我们此次的主题是:用Python实现一个迷宫生成器。

首先展示一下效果图:

我们先分析一下所需的库:

既然是生成器,每次生成的迷宫一模一样显然是说不过去的。因此,我们不可避免地要使用随机数(Random库)。迷宫一定是要绘制的,所以需要有一个GUI库或绘图库,这里我使用Pygame(Tkinter或Turtle其实都可以做到,但毕竟Pygame比较顺手)。与Pygame搭配,Sys似乎也是需要的(用于退出程序,但其实不使用似乎也无伤大雅)。然后是Tkinter.filedialog,主要用于询问保存路径(生成的迷宫总得保存吧)。当然,用Time加一个计时器似乎是锦上添花。

于是,就有:

#coding:utf-8
import contextlib
with contextlib.redirect\_stdout(None):import pygame
import random
import sys
import time
from tkinter.filedialog import *

这里要说明的是,由于导入Pygame时会输出版本信息等很多内容(这很影响美感),我们需要使用Contextlib阻止它输出。

接下来,我们需要询问一些参数:

a=int(input("列数:"))
b=int(input("行数:"))
l=int(input("大小:"))
saveit=input("是否保存:")

然后,就要运行生成迷宫的程序了。同时,我们有必要计录一下时间(相当于开启计时器):

print("生成中...")
e = time.time()

然后就是正式生成迷宫。在介绍这部分代码之前,我们需要了解一下算法:

第一步,生成一个由迷宫单元(白格)和墙(黑格)组成的网格。一行中迷宫单元的数量为迷宫的列数,一列找迷宫单元的数量为迷宫的行数。令左上角的迷宫单元为起点,右下角的迷宫单元为终点,打破起点左边与终点右边的墙,如图所示:

第二步,访问各迷宫单元。将起点标记为当前迷宫单元,当存在未被访问的迷宫单元(凡是曾经成为过当前迷宫单元的迷宫单元,都视为已访问)时,重复执行:

  • 将周围的未被访问的迷宫单元加入表格;
  • 如果表格中有迷宫单元:
    • 将当前迷宫单元入栈(可以理解为将其加入一个叫做栈的表格);
    • 从表格中随机选择一个迷宫单元;
    • 打破当前迷宫单元与选择的迷宫单元之间的墙;
    • 将选择的迷宫单元标记为当前迷宫单元;
  • 如果表格中没有迷宫单元:
    • 栈顶迷宫单元出栈(可以理解为将栈中的最后一个元素获取并删除);
    • 将出栈的迷宫单元设为当前迷宫单元;

在循环结束以后,就会出现像文章开头效果图一样的结果。

接下来,我们就要将文字化的算法转化为Python的代码。

首先,程序是不认识图片的,它认识的是数据。所以我们需要设置一个二维列表,以此来用一串数据表示当前的图像。当然,我们可以顺便将第一步的设置一起完成:

alist = []
aa=0
need=[]
for j in range(2*a+1):if aa==0:aa = 1alistone = []for i in range(2*b+1):alistone.append(1)alist.append(alistone)else:aa=0alistone = []bb=0for i in range(2*b+1):if bb==0:bb=1alistone.append(1)else:bb = 0need.append((j,i))alistone.append(0)alist.append(alistone)
alist[0][1]=0
alist[-1][-2]=0

可以看到,除此以外我们还建立了一个列表need,里面存储了所有的迷宫单元。它的作用就是判断迷宫单元是否被访问,每次访问都会将迷宫单元从表格中删除,当表格中没有迷宫单元时,就说明所有迷宫单元都被访问了。

x=1
y=1
need.remove((1, 1))
listing=[]
while len(need)>0:aroundit=[]try:if x-2<0:print(1+"1")alist[x-2][y]=0if (x-2,y) in need:aroundit.append("alist[x-1][y],x=(0,x-2)")except:while False:print()try:alist[x+2][y]=0if (x+2,y) in need:aroundit.append("alist[x+1][y],x=(0,x+2)")except:while False:print()try:alist[x][y+2]=0if (x,y+2) in need:aroundit.append("alist[x][y+1],y=(0,y+2)")except:while False:print()try:if y-2<0:print(1+"1")alist[x][y-2]=0if (x,y-2) in need:aroundit.append("alist[x][y-1],y=(0,y-2)")except:while False:print()if len(aroundit)>0:listing.append((x,y))exec(random.choice(aroundit))need.remove((x, y))else:x,y=listing[-1]listing.pop()

而这些内容,就是第二步。其算法我已经解释过,唯一一个微小的不同是,在此处我们并没有在列表中加入相邻迷宫单元的坐标,而是将其对应的破墙和标记为当前迷宫单元的代码以字符串的形式存储在表格中,并在随机选择出某个迷宫单元所对应的字符串后,使用exec将其转换为代码并运行(这可以节省一些代码)。

print("完成!用时{}秒".format(time.time()-e))

打印完生成迷宫的用时后,我们需要将表格中的数据转化为图像了。当然,在此之前,我们要先确定图片保存的位置。

if saveit=="1":ccc = askdirectory()h=""bbbbb=1while True:try:open("{}/{}×{}迷宫{}.png".format(ccc,a,b,h),"r")h="({})".format(bbbbb)except:breakbbbbb+=1

由于使用时有可能选择不保存图片,因此要先判断你的选择是保存还是不保存。这里字符“1”表示保存(输入其他,自然就是不保存了)。然后我们需要让你选择保存路径(askdirectory()询问的是文件路径,不需要选择文件名)。然后,我们要确定文件名称:“a×b迷宫.png”。这里需要判断指定路径是否存在此名称的文件,如果存在,则我们需要在后面加上序号。总而言之,通过这串代码,我们已经将迷宫的路径+文件名确定了。

pygame.init()
icon=pygame.image.load("迷宫.png")
pygame.display.set\_icon(icon)
screen=pygame.display.Info()
screen = pygame.display.set\_mode((l*(2*a+1),l*(2*b+1)))
pygame.display.set\_caption('迷宫')
screen.fill("white")
c = pygame.Surface((l, l), flags=pygame.HWSURFACE)
c.fill(color='white')
d = pygame.Surface((l, l), flags=pygame.HWSURFACE)
d.fill(color='black')
for i in range(2*a+1):for j in range(2*b+1):if alist[i][j]==0:screen.blit(c, (i*l, j*l))elif alist[i][j]==1:screen.blit(d, (i*l, j*l))
pygame.display.flip()
if saveit=="1":pygame.image.save(screen, "{}/{}×{}迷宫{}.png".format(ccc, a, b, h))
while True:for event in pygame.event.get():if event.type == pygame.QUIT:pygame.quit()sys.exit()

代码中使用的图片“迷宫.png”(名称不太对,下载以后要重新命名一下):

这里主要是Pygame的基本设置,并将表格内容图像化。每一个数字代表一个方块,而数字的值则决定了方块的颜色,数字在表格中的位置决定了方块的位置。就这样,我们呢将表格完全转化成了图像。当然,我们还需要用pygame.image.save()函数将图像保存为图片文件。

这样,这个生成器似乎完成了。

它运行良好,但当迷宫比较复杂时,暴露出一个问题(下图是100×100的迷宫):

由于正确路径过于曲折,在复杂度较高时,这个迷宫的难度会变得极高!

难度高,在某方面上讲,的确是好事。但当你向你的朋友们展示这个迷宫时,如果你自己也无法得出正确的路径,这不是很扫兴吗?

因此,一个寻路算法变得非常有必要。

寻路算法的大体思路:

在生成的迷宫中,白格为路,黑格为墙。将起点设置为当前位置,重复执行直到终点成为当前位置:

  • 将当前位置标记为正确路径;
  • 将周围未标记的路加入一个表格;
  • 如果表格不空:
  • 将当前位置入栈;
  • 从表格中随机选择一条路,并将其设为当前位置;
  • 如果表格是空的:
  • 栈顶的路出栈;
  • 将其设为当前位置;

通过这个算法,我们可以试出正确的路径(如图):

代码的实现:

x2=0
y2=1
listing2=[]
while not(alist[-1][-2]==2):alist[x2][y2]=3around2=[]try:if x2-1<0:print(1+"1")if alist[x2-1][y2]==0:around2.append("x2=x2-1")except:while False:print()try:if alist[x2+1][y2]==0:around2.append("x2=x2+1")except:while False:print()try:if alist[x2][y2+1]==0:around2.append("y2=y2+1")except:while False:print()try:if y2-1<0:print(1+"1")if alist[x2][y2-1]==0:around2.append("y2=y2-1")except:while False:print()if len(around2)>0:listing2.append((x2,y2))exec(random.choice(around2))else:alist[x2][y2]=2x2,y2=listing2[-1]listing2.pop()
alist[-1][-2]=3
for i in range(len(alist)):for j in range(len(alist[0])):if alist[i][j]==2:alist[i][j]=0

同时,图像绘制的过程也要作出一些改动,以显示正确路径:

if saveit=="1":ccc = askdirectory()h=""bbbbb=1while True:try:open("{}/{}×{}迷宫{}.png".format(ccc,a,b,h),"r")open("{}/{}×{}迷宫(正确线路){}.png".format(ccc,a,b,h),"r")h="({})".format(bbbbb)except:breakbbbbb+=1
pygame.init()
icon=pygame.image.load("迷宫.png")
pygame.display.set\_icon(icon)
screen=pygame.display.Info()
screen = pygame.display.set\_mode((l*(2*a+1),l*(2*b+1)))
pygame.display.set\_caption('迷宫')
screen.fill("white")
if saveit=="1":c = pygame.Surface((l, l), flags=pygame.HWSURFACE)c.fill(color='white')d = pygame.Surface((l, l), flags=pygame.HWSURFACE)d.fill(color='black')f = pygame.Surface((l, l), flags=pygame.HWSURFACE)f.fill(color='white')for i in range(2 * a + 1):for j in range(2 * b + 1):if alist[i][j] == 0:screen.blit(c, (i * l, j * l))elif alist[i][j] == 1:screen.blit(d, (i * l, j * l))else:screen.blit(f, (i * l, j * l))pygame.image.save(screen, "{}/{}×{}迷宫{}.png".format(ccc, a, b, h))c = pygame.Surface((l, l), flags=pygame.HWSURFACE)c.fill(color='white')d = pygame.Surface((l, l), flags=pygame.HWSURFACE)d.fill(color='black')f = pygame.Surface((l, l), flags=pygame.HWSURFACE)f.fill(color='red')for i in range(2 * a + 1):for j in range(2 * b + 1):if alist[i][j] == 0:screen.blit(c, (i * l, j * l))elif alist[i][j] == 1:screen.blit(d, (i * l, j * l))else:screen.blit(f, (i * l, j * l))pygame.image.save(screen, "{}/{}×{}迷宫(正确线路){}.png".format(ccc, a, b, h))
c = pygame.Surface((l, l), flags=pygame.HWSURFACE)
c.fill(color='white')
d = pygame.Surface((l, l), flags=pygame.HWSURFACE)
d.fill(color='black')
f = pygame.Surface((l, l), flags=pygame.HWSURFACE)
f.fill(color='white')
for i in range(2*a+1):for j in range(2*b+1):if alist[i][j]==0:screen.blit(c, (i*l, j*l))elif alist[i][j]==1:screen.blit(d, (i*l, j*l))else:screen.blit(f,(i*l, j*l))
pygame.display.flip()
aaaaaaa = 0
while True:for event in pygame.event.get():if event.type == pygame.QUIT:pygame.quit()sys.exit()if event.type == pygame.MOUSEBUTTONDOWN:if aaaaaaa == 1:aaaaaaa = 0c = pygame.Surface((l, l), flags=pygame.HWSURFACE)c.fill(color='white')d = pygame.Surface((l, l), flags=pygame.HWSURFACE)d.fill(color='black')f = pygame.Surface((l, l), flags=pygame.HWSURFACE)f.fill(color='white')for i in range(2 * a + 1):for j in range(2 * b + 1):if alist[i][j] == 0:screen.blit(c, (i * l, j * l))elif alist[i][j] == 1:screen.blit(d, (i * l, j * l))else:screen.blit(f, (i * l, j * l))pygame.display.flip()else:aaaaaaa = 1c = pygame.Surface((l, l), flags=pygame.HWSURFACE)c.fill(color='white')d = pygame.Surface((l, l), flags=pygame.HWSURFACE)d.fill(color='black')f = pygame.Surface((l, l), flags=pygame.HWSURFACE)f.fill(color='red')for i in range(2 * a + 1):for j in range(2 * b + 1):if alist[i][j] == 0:screen.blit(c, (i * l, j * l))elif alist[i][j] == 1:screen.blit(d, (i * l, j * l))else:screen.blit(f, (i * l, j * l))pygame.display.flip()

通过这些改动,显示正确路径的效果就实现了。生成完成以后,窗口上显示的是没有正确路径的迷宫,而点击窗口后,正确的路径就会显示(再次点击隐藏)。

刚刚那张100×100的迷宫,其正确路径是:

可以看出,本文中所用的算法生成的迷宫,其正确路径还是非常曲折的(难度很高)。你何不将其发给你的朋友,让其破解一下呢?

完整的代码:

#coding:utf-8
import contextlib
with contextlib.redirect\_stdout(None):import pygame
import random
import sys
import time
from tkinter.filedialog import *
a=int(input("列数:"))
b=int(input("行数:"))
l=int(input("大小:"))
saveit=input("是否保存:")
print("生成中...")
e = time.time()
alist = []
aa=0
need=[]
for j in range(2*a+1):if aa==0:aa = 1alistone = []for i in range(2*b+1):alistone.append(1)alist.append(alistone)else:aa=0alistone = []bb=0for i in range(2*b+1):if bb==0:bb=1alistone.append(1)else:bb = 0need.append((j,i))alistone.append(0)alist.append(alistone)
alist[0][1]=0
alist[-1][-2]=0
x=1
y=1
need.remove((1, 1))
listing=[]
while len(need)>0:aroundit=[]try:if x-2<0:print(1+"1")alist[x-2][y]=0if (x-2,y) in need:aroundit.append("alist[x-1][y],x=(0,x-2)")except:while False:print()try:alist[x+2][y]=0if (x+2,y) in need:aroundit.append("alist[x+1][y],x=(0,x+2)")except:while False:print()try:alist[x][y+2]=0if (x,y+2) in need:aroundit.append("alist[x][y+1],y=(0,y+2)")except:while False:print()try:if y-2<0:print(1+"1")alist[x][y-2]=0if (x,y-2) in need:aroundit.append("alist[x][y-1],y=(0,y-2)")except:while False:print()if len(aroundit)>0:listing.append((x,y))exec(random.choice(aroundit))need.remove((x, y))else:x,y=listing[-1]listing.pop()
x2=0
y2=1
listing2=[]
while not(alist[-1][-2]==2):alist[x2][y2]=3around2=[]try:if x2-1<0:print(1+"1")if alist[x2-1][y2]==0:around2.append("x2=x2-1")except:while False:print()try:if alist[x2+1][y2]==0:around2.append("x2=x2+1")except:while False:print()try:if alist[x2][y2+1]==0:around2.append("y2=y2+1")except:while False:print()try:if y2-1<0:print(1+"1")if alist[x2][y2-1]==0:around2.append("y2=y2-1")except:while False:print()if len(around2)>0:listing2.append((x2,y2))exec(random.choice(around2))else:alist[x2][y2]=2x2,y2=listing2[-1]listing2.pop()
alist[-1][-2]=3
for i in range(len(alist)):for j in range(len(alist[0])):if alist[i][j]==2:alist[i][j]=0
print("完成!用时{}秒".format(time.time()-e))
if saveit=="1":ccc = askdirectory()h=""bbbbb=1while True:try:open("{}/{}×{}迷宫{}.png".format(ccc,a,b,h),"r")open("{}/{}×{}迷宫(正确线路){}.png".format(ccc,a,b,h),"r")h="({})".format(bbbbb)except:breakbbbbb+=1
pygame.init()
icon=pygame.image.load("迷宫.png")
pygame.display.set\_icon(icon)
screen=pygame.display.Info()
screen = pygame.display.set\_mode((l*(2*a+1),l*(2*b+1)))
pygame.display.set\_caption('迷宫')
screen.fill("white")
if saveit=="1":c = pygame.Surface((l, l), flags=pygame.HWSURFACE)c.fill(color='white')d = pygame.Surface((l, l), flags=pygame.HWSURFACE)d.fill(color='black')f = pygame.Surface((l, l), flags=pygame.HWSURFACE)f.fill(color='white')for i in range(2 * a + 1):for j in range(2 * b + 1):if alist[i][j] == 0:screen.blit(c, (i * l, j * l))elif alist[i][j] == 1:screen.blit(d, (i * l, j * l))else:screen.blit(f, (i * l, j * l))pygame.image.save(screen, "{}/{}×{}迷宫{}.png".format(ccc, a, b, h))c = pygame.Surface((l, l), flags=pygame.HWSURFACE)c.fill(color='white')d = pygame.Surface((l, l), flags=pygame.HWSURFACE)d.fill(color='black')f = pygame.Surface((l, l), flags=pygame.HWSURFACE)f.fill(color='red')for i in range(2 * a + 1):for j in range(2 * b + 1):if alist[i][j] == 0:screen.blit(c, (i * l, j * l))elif alist[i][j] == 1:screen.blit(d, (i * l, j * l))else:screen.blit(f, (i * l, j * l))pygame.image.save(screen, "{}/{}×{}迷宫(正确线路){}.png".format(ccc, a, b, h))
c = pygame.Surface((l, l), flags=pygame.HWSURFACE)
c.fill(color='white')
d = pygame.Surface((l, l), flags=pygame.HWSURFACE)
d.fill(color='black')
f = pygame.Surface((l, l), flags=pygame.HWSURFACE)
f.fill(color='white')
for i in range(2*a+1):for j in range(2*b+1):if alist[i][j]==0:screen.blit(c, (i*l, j*l))elif alist[i][j]==1:screen.blit(d, (i*l, j*l))else:screen.blit(f,(i*l, j*l))
pygame.display.flip()
aaaaaaa = 0
while True:for event in pygame.event.get():if event.type == pygame.QUIT:pygame.quit()sys.exit()if event.type == pygame.MOUSEBUTTONDOWN:if aaaaaaa == 1:aaaaaaa = 0c = pygame.Surface((l, l), flags=pygame.HWSURFACE)c.fill(color='white')d = pygame.Surface((l, l), flags=pygame.HWSURFACE)d.fill(color='black')f = pygame.Surface((l, l), flags=pygame.HWSURFACE)f.fill(color='white')for i in range(2 * a + 1):for j in range(2 * b + 1):if alist[i][j] == 0:screen.blit(c, (i * l, j * l))elif alist[i][j] == 1:screen.blit(d, (i * l, j * l))else:screen.blit(f, (i * l, j * l))pygame.display.flip()else:aaaaaaa = 1c = pygame.Surface((l, l), flags=pygame.HWSURFACE)c.fill(color='white')d = pygame.Surface((l, l), flags=pygame.HWSURFACE)d.fill(color='black')f = pygame.Surface((l, l), flags=pygame.HWSURFACE)f.fill(color='red')for i in range(2 * a + 1):for j in range(2 * b + 1):if alist[i][j] == 0:screen.blit(c, (i * l, j * l))elif alist[i][j] == 1:screen.blit(d, (i * l, j * l))else:screen.blit(f, (i * l, j * l))pygame.display.flip()

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

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

相关文章

数组的操作

有关操作数组的方法(函数): (常用)push() 从尾部添加新元素 操作的是原数组 pop() 从尾部删除一个元素 unshift() 从开头添加元素 shift() 从开头删除元素 slice(start, end) 获取数组中某些元素&#xff0c;返回一个新数组&#xff1b;从start下标位置起开始截取到end下标(不…

MSP430F5529 DriverLib 库函数I2C驱动OLED屏幕

目录I2C驱动代码MSP430F5529_I2C.cMSP430F5529_I2C.hOLED初始化及测试OLED驱动代码OLED.cOLED.hOLED_Font.h显示效果平台&#xff1a;Code Composer Studio 10.4.0 MSP430F5529 LaunchPad™ Development Kit (MSP‑EXP430F5529LP) I2C驱动代码 P3.0为SDA&#xff0c;P3.1为S…

java经典算法四十题

java经典算法四十题 【程序8】题目&#xff1a;求saaaaaaaaaaaa...a的值&#xff0c;其中a是一个数字。例如222222222222222(此时共有5个数相加)&#xff0c;几个数相加有键盘控制。1.程序分析&#xff1a;关键是计算出每一项的值。import java.io.*; public class Sumloop { p…

html调用servlet(JDBC在Servlet中的使用)(2)

5.修改数据 5.1编写查询条件页面 修改单条数据的时候&#xff0c;首先是查询出单个数据的详细信息&#xff0c;然后根据实际需要部分修改或者全部修改。修改之后&#xff0c;数据会提交到数据库&#xff0c;数据库中保存更新以后的数据。 查询出单条数据的查询条件页面代码如下…

gulp基础使用方法记录

一、开始 使用gulp&#xff0c;需知道4个API&#xff1a; gulp.task():用来定义任务, 格式&#xff1a;gulp.task(name[, deps], fn) name 为任务名 deps 是当前定义的任务需要依赖的其他任务&#xff0c;为一个数组。当前定义的任务会在所有依赖的任务执行完毕后才开始执行。如…

dolphinscheduler简单任务定义及复杂的跨节点传参

&#x1f680; 优质资源分享 &#x1f680; 学习路线指引&#xff08;点击解锁&#xff09;知识定位人群定位&#x1f9e1; Python实战微信订餐小程序 &#x1f9e1;进阶级本课程是python flask微信小程序的完美结合&#xff0c;从项目搭建到腾讯云部署上线&#xff0c;打造一…

【 Grey Hack 】万金油脚本:常见端口漏洞检测

目录脚本源码用法效果及示例SSH 端口FTP 端口版本&#xff1a;Grey Hack v0.7.3618 - Alpha 适用于SSH (22) 端口、FTP (21) 端口、HTTP (80) 端口、SMTP (25) 端口及3306/3307 端口 。 脚本源码 if params.len ! 2 or params[0] "-h" or params[0] "--help…

JUC源码学习笔记1——AQS和ReentrantLock

&#x1f680; 优质资源分享 &#x1f680; 学习路线指引&#xff08;点击解锁&#xff09;知识定位人群定位&#x1f9e1; Python实战微信订餐小程序 &#x1f9e1;进阶级本课程是python flask微信小程序的完美结合&#xff0c;从项目搭建到腾讯云部署上线&#xff0c;打造一…

Android 应用内直接跳转酷市场

不确定酷市场后期是否还会该包名或者路径,目前的7.9 版本测试通过. private void gotoCoolapkMarket() {try {Intent intent new Intent(Intent.ACTION_VIEW);intent.setData(Uri.parse("market://details?id" getPackageName()));intent.setClassName("com.…

【 Grey Hack 】万金油脚本:常见端口获取shell

目录脚本源码用法效果及示例成功示例FTP &#xff08;21&#xff09;端口HTTP &#xff08;80&#xff09;端口失败示例版本&#xff1a;Grey Hack v0.7.3618 - Alpha 适用于SSH (22) 端口、FTP (21) 端口、HTTP (80) 端口、SMTP (25) 端口及3306/3307 端口。 脚本源码 if pa…

Date 类型转换

Date类型默认固定输出格式是 “Fri Apr 12 17:26:23 CST 2013” 该类型属性本身无法改变格式&#xff0c;要想在前台jsp等页面呈现出你想要的格式就需要改变类型。 Date 转换成 String      转换成其它如“YYYY-MM-DD”,"YYYY-MM-DD hh:mm:ss"等之类的格式 Si…

ECharts整合HT#160;for#160;Web的网络拓扑图应用

ECharts图形组件在1.0发布的时候我就已经有所关注&#xff0c;今天在做项目的时候遇到了图标的需求&#xff0c;在HT for Web上也有图形组件的功能&#xff0c;但是在尝试了下具体实现后&#xff0c;发现HT for Web的图形组件是以矢量的格式来呈现的&#xff0c;在展现上可以有…

一个月后,我们又从 MySQL 双主切换成了主 - 从!

&#x1f680; 优质资源分享 &#x1f680; 学习路线指引&#xff08;点击解锁&#xff09;知识定位人群定位&#x1f9e1; Python实战微信订餐小程序 &#x1f9e1;进阶级本课程是python flask微信小程序的完美结合&#xff0c;从项目搭建到腾讯云部署上线&#xff0c;打造一…

如何进行有效的沟通----日常沟通及会议

日常开发和工作中会经常遇到沟通不畅的问题&#xff0c;"communication" 不论是在学术还是实践中都是一个很重要的议题。因为低效的沟通造成的开发事故有时候是灾难性的。 沟通的问题为认为本质上就是信息不对称。下面以日常沟通及会议沟通做一些浅显的讨论&#xff…

【 Grey Hack 】万金油脚本:常见端口获取Password

目录脚本源码用法效果及示例SSH &#xff08;80&#xff09;端口FTP &#xff08;21&#xff09;端口HTTP &#xff08;80&#xff09;端口失败示例SMTP &#xff08;25&#xff09;端口版本&#xff1a;Grey Hack v0.7.3618 - Alpha 适用于SSH (22) 端口、FTP (21) 端口、HTTP…

什么时候用synchronized

解决安全问题的方式&#xff1a; java中提供了一个同步机制&#xff1a; 解决原理&#xff1a;让多条操作共享数据的代码在某一个时间段&#xff0c;被一个线程执行完&#xff0c;在执行过程中&#xff0c;其它线程不可以参与执行 同步格式&#xff1a; 同步代码块&#xff1a;…

pygame写游戏,常用代码记录

2019独角兽企业重金招聘Python工程师标准>>> pygame 写起游戏来还是挺不错的&#xff0c;不过我也没用过别的什么东西写&#xff0c;所以也没什么发言权。 些游戏我是从这篇文章开始入门的13岁天才儿童教你写游戏 下面是一些常用的代码片段&#xff0c;记录下来&…

每天一个linxu命令6之jps  查看java进程的端口

jps -- Java Virtual Machine Process Status Tool 可以列出本机所有Java进程的pid jps [ options ] [ hostid ] 选项 -q 仅输出VM标识符&#xff0c;不包括class name,jar name,arguments in main method -m 输出main method的参数 -l 输出完全的包名&#xff0c;应用主类名&…

聊聊 C++ 中几类特殊成员函数

&#x1f680; 优质资源分享 &#x1f680; 学习路线指引&#xff08;点击解锁&#xff09;知识定位人群定位&#x1f9e1; Python实战微信订餐小程序 &#x1f9e1;进阶级本课程是python flask微信小程序的完美结合&#xff0c;从项目搭建到腾讯云部署上线&#xff0c;打造一…

poj2975——Caesar密码

原题&#xff1a; Description 据说最早的 密码来自于罗马的凯撒大帝。消息加密的办法是&#xff1a;对消息原文中的每个字母&#xff0c;分别用该字母之后的第5个字母替换&#xff08;例如&#xff1a;消息原文中的每个字母A都分别替换成字母F&#xff09;。而你要获得消息原文…