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:批量生成随机字符文件名案例 * *** ...
随机推荐
- Ubuntu各个版本支持时间
早期版本:
- UVa 10132 - File Fragmentation
题目大意:有n个相同的文件,每个文件从中间分为两半,现在给你这2n个文件碎片,求原来完整的文件. 找出文件碎片长度的最大值和最小值,二者相加可得到原来文件的长度len.然后逐个进行拼接,将拼接后长度等 ...
- 有限状态机(Finite-state machine)
var menu = { // 当前状态 currentState: 'hide', // 绑定事件 initialize: function() { var self = this; self.on ...
- spring整合mybatis,springMVC的0配置文件方式
0配置文件的形式主要是采用spring3.0提供的@configuration注解和spring容器在启动的时候会加载实现了WebApplicationInitializer的类,并调用其onStar ...
- cpu95%,查找问题sql
收到一封告警邮件: Load average on xxx_server reached critical threshold values - 169.5 Current Load Avg = 16 ...
- Tsinsen A1333: 矩阵乘法(整体二分)
http://www.tsinsen.com/A1333 题意:-- 思路:和之前的第k小几乎一样,只不过把一维BIT换成二维BIT而已.注意二维BIT写法QAQ #include <cstdi ...
- 第十八篇、OC_使用OAStackView FDStackView (第三方框架)可以使用在ios 7及以上的版本
UILabel *view1 = [[UILabel alloc]init]; view1.text = @"Label1"; view1.backgroundColor = [U ...
- Win7 x64 Eclipse无法识别手机 / adb interface有黄色感叹号,无法识别
今天公司停电,因此把安卓项目带回宿舍做.宿舍的笔记本,装的是Win7 x64,手机连上电脑后,windows可以识别,但Eclipse的DDMS中却无法识别,什么都没有: 然后打开设备管理器查看,发现 ...
- LINQ to Sql系列一 增,删,改
首先,我们来了解一下LINQ to sql 是什么,我想从以下几点来做说明. 1,LINQ是从.net framework 3.0开始引入的的语言特性,主要是用来对集合数据进行操作的.2,LINQ t ...
- NodeJS的Cluster模块使用
一.前言大家都知道nodejs是一个单进程单线程的服务器引擎,不管有多么的强大硬件,只能利用到单个CPU进行计算.所以,有人开发了第三方的cluster,让node可以利用多核CPU实现并行. 随着n ...