MegCup 2017 极客挑战赛 初赛试题
看着像八卦,数数不是八卦,是29卦
每卦又有29个小弧
所以是29×29个bit
这29×29个bit怎么理解呢?并且从哪一卦开始到哪一卦结束?是先环向层层向里走还是先径向逐卦走?
我想不出来。
我猜测:
可能是这个二进制串可以翻译成某个ASCII字符串,可能这个二进制串是通过Base64编码过的,可能性太多了
问林教主。
林教主说:从圆心沿180度方向向外剪开,剪开之后就得到一个小扇子,这个小扇子其实是一个正方形,这个正方形图片就是一个二维码,拿出手机来一扫就进入一个URL链接,就大功告成了。
问怎么想出来的?
林教主说:二维码4个角处有3个正方形,看到了180度方向有两个正方形,这个八卦本身又像二维码。
问怎么转化成正方形二维码?
林教主说:一张笔一支纸一小时
我说:那还了得
这个可以编程实现。
关键是:根据(第几个扇形,第几个弧)两个变量可以求出来该小弧的颜色。
说起来简单,操作起来还是遇到不少问题:
- 中间有一个小圆圈,这个小圆圈的半径必须求出来。这个问题可以通过图形化界面,鼠标悬浮一下大约估计一下。
- 每个小弧的厚度必须求出来,这个当然可以根据第一个问题中小圆圈的半径求出来。
- 这个图片格式是RGBA格式的,也就是说包含透明色,透明色默认就是白色,而不透明色可能是白色也可能是黑色,每个像素的RGB也不是纯黑纯白,所以需要“纯化一下”,让它变成非黑即白的模式。这是一个预处理的过程。
下面是代码,用PIL图片处理模块和tkinter两个模块
"""
图形化界面确定一些参数:比如中间圆圈的半径
"""
from PIL import Image, ImageTk
import tkinter
import math
window = tkinter.Tk()
img = Image.open("w.png")
sz = img.size[0]
def init():
# 预处理图片,使之变成纯黑纯白
def getColor(c):
# 去除噪声
if c[3] == 0:
return 255, 255, 255, 255
if c[3] == 255:
if c[0] > 128 and c[1] > 128 and c[2] > 128:
return 255, 255, 255, 255
return 0, 0, 0, 255
for i in range(sz):
for j in range(sz):
img.putpixel((i, j), getColor(img.getpixel((i, j))))
init()
image = ImageTk.PhotoImage(img)
canvas = tkinter.Canvas(width=image.width(), height=image.height())
canvas.pack()
canvas.create_image(sz / 2, sz / 2, image=image)
def getBit(x, y):
c = sz / 2 # 中心坐标
r = 44 # 中心圆盘半径
w = (c - r) / 29
R = r + (x + 0.5) * w
theta = (math.pi * 2 / 29) * (y + 0.5)
x, y = c - R * math.cos(theta), c - R * math.sin(theta)
x, y = int(x), int(y)
color = img.getpixel((x, y))
return color[:3]
def hover(e):
window.title("%d,%d,%s" % (e.x, e.y, str(img.getpixel((e.x, e.y)))))
def go():
# 获取二维码图片
ans = Image.new("RGB", (30, 30))
for i in range(29):
for j in range(29):
ans.putpixel((i, j), getBit(i, j))
ans = ans.resize((290, 290))
ans.show("haha")
def getParams():
# 获取参数
window.bind("<Motion>", hover)
window.mainloop()
# getParams()
go()
MegCup 2017 极客挑战赛 初赛试题的更多相关文章
- 银联高校极客挑战赛 初赛 第一场 B
自学图论的码队弟弟 试图写非递归求解,然后TLE了一下午==,全程找不到bug,换成递归,一发AC 判断环写得很丑== #include<bits/stdc++.h> using name ...
- 银联高校极客挑战赛第一场 A.码队女朋友的王者之路[水题]
目录 题目地址 题干 代码和解释 题目地址 计蒜客回顾比赛 码队女朋友的王者之路 题干 代码和解释 本题难度不大,但是一开始没有读懂题,以为净胜场次是确定的,没有"最高净胜场次"的 ...
- [51NOD]BSG白山极客挑战赛
比赛链接:http://www.51nod.com/contest/problemList.html#!contestId=21 /* ━━━━━┒ギリギリ♂ eye! ┓┏┓┏┓┃キリキリ♂ min ...
- PHP极客水平测试——给创业公司用的远程面试题
出了份面试题<PHP极客水平测试>,创业公司可以用这个远程笔试啦,先答题,看答案合适了再邀请面试.希望对创业公司有所帮助,欢迎围观提建议哦^_^ 题目会持续更新. 答题地址:http:// ...
- [web建站] 极客WEB大前端专家级开发工程师培训视频教程
极客WEB大前端专家级开发工程师培训视频教程 教程下载地址: http://www.fu83.cn/thread-355-1-1.html 课程目录:1.走进前端工程师的世界HTML51.HTML5 ...
- <路径算法>哈密顿路径变种问题(2016华为软件精英挑战赛初赛)
原创博客,转载请联系博主! 前言:几天前华为的这个软件精英(算法外包)挑战赛初赛刚刚落幕,其实这次是我第二次参加,只不过去年只入围到了64强(32强是复赛线),最后搞到了一个华为的一顶帽子(感谢交大l ...
- 极客圈(一)树莓派3B协同Python打造个性化天气闹钟
人生苦短,我用Python~ 一直想自己折腾些极客的东西出来,供自己使用或者是供他人使用.一则可能对自己的生活是一种帮助,二则是对自己技能的提高,三则显得高大上,一直努力,一直提高,一直Happy!~ ...
- "做中学"之“极客时间”课程学习指导
目录 "做中学"之"极客时间"课程学习指导 所有课程都可以选的课程 Java程序设计 移动平台开发 网络攻防实践 信息安全系统设计基础 信息安全专业导论 极客时 ...
- (转)2017年最新企业面试题之shell(一,二)
2017年最新企业面试题之shell(一) ********************************************** 企业Shell面试题1:批量生成随机字符文件名案例 * *** ...
随机推荐
- IOS开发-ObjC-NSDictionary
OC中Foundation框架中有字典类,字典分不可变字典(NSDictionary)和可变字典(NSMutableDictionary),它们的使用如下: 不可变字典: //------------ ...
- python流程控制:for循环
for循环: 先来看一个猜年龄的小程序: AGE = 23 count = 0 for i in range(10): if count == 3: u_count = input("y|n ...
- 安卓selector
定义styles.xml <?xml version="1.0" encoding="utf-8"?> <resources> < ...
- redis 配置(1)
redis配置密码 1.通过配置文件进行配置yum方式安装的redis配置文件通常在/etc/redis.conf中,打开配置文件找到 #requirepass foobared 去掉行前的注释,并修 ...
- [转python 父类可以调用子类的方法
问题描述:我也是在读500 Line 里满的DBDB 的代码时发现的,python的父类可以调用子类的方法,这跟平常习惯的理解方式很不一样,所以就查了下原因,记录如下: 1.现象:最近使用到了So ...
- Nginx中的信号量(信号控制)
- sklearn数据预处理-scale
对数据按列属性进行scale处理后,每列的数据均值变成0,标准差变为1.可通过下面的例子加深理解: from sklearn import preprocessing import numpy as ...
- 除trigger()方法外的jquery手动触发事件
trigger()可以触发指定事件是大家基本都知道的了. 除了trigger()之外我们也可以这样来触发: html <div id="box" style="he ...
- 十二生肖&天干地支
看相:http://baike.baidu.com/view/833122.htm?fr=aladdin 八字:http://baike.baidu.com/view/17127.htm?fr=ala ...
- MonthCalendar控件
MonthCalendar控件 功能,直接显示月历,