ARTS Week 5
Nov 25, 2019 ~ Dec 1, 2019
Algorithm
深度优先搜索--书籍分配
题目描述:有b1~b5五本书,要分配给五个学生,分别是a1~a5。但每个学生都有其喜欢的书,要检查是否可以让每位同学都获得自己喜欢的书。书籍喜好表如下(Y表示喜欢):
| b1 | b2 | b3 | b4 | b5 | |
|---|---|---|---|---|---|
| a1 | Y | Y | Y | ||
| a2 | Y | Y | Y | ||
| a3 | Y | ||||
| a4 | Y | Y | |||
| a5 | Y |
思路
- 每本书对于每个人的状态都是“未分配”状态
- 为其中一个人分配一本他喜欢的书,分配后将该书标记为“已分配”,可能会出现以下两种情况:
- 若分配完所有书,则说明产生了一个合理的方案。输出该方案,继续尝试有无新的方案。
- 若分配到下一个人没有可控分配的他喜欢的书,则退回上一状态重新分配
实现
# 检查该学生是否喜欢这本书
def judge(j, k):
name = student[k]
book = books[j]
if book in like[name]:
return True
else:
return False
# 打印一种结果
def answer(L):
print('一种分配方案为:')
for i in range(n):
print(student[i], '->', L[i])
# 深度优先搜索
def book_dfs(L, k):
if k == n:
answer(L)
else:
for j in range(n):
if judge(j, k) and visited[j] == 0:
# j本书分配给第k个人是否合理
L[k] = books[j]
visited[j] = 1
book_dfs(L, k+1)
visited[j] = 0
student = ['a1', 'a2', 'a3', 'a4', 'a5']
books = ['A', 'B', 'C', 'D', 'E']
like = {'a1':['A','B','D'], 'a2':['B','C','E'], 'a3':['B'], 'a4':['A','C'], 'a5':['D','E']}
Review
如何保护好自己的密码免遭侵害,可以阅读火狐给出的建议,英文原文
了解黑客的工作方式
- 最初的目标不是针对具体某个人的信息,而是许多人的信息。
- 所有的数据都是有价值的,信息可以被用来出售,尝试其他账户等
- 有的密码是很弱的,很容易被猜测出来,可以参考2018年最差的100个密码,密码
123456位于榜首 - 一个密码可以解开多个账户。我相信大部分人总或多或少的账户密码是相同的。
- 黑客不在乎你有多少钱。参见第2条
数据泄漏后怎么办
- 阅读泄漏的时间,因为泄漏未必会被即时发现,有一定的滞后性,可能是几天几个月甚至几年
- 检查自己是否注册过该账户,虽然很少发生
- 尽快更改密码,不仅要更改被泄露账户的密码,也要修改密码相同的其他账户密码
- 如果收到了其他损失,比如金钱、信用,请及时联系相关部门处理
如何创建强密码
先查看2018年排名前25的弱密码
1 123456
2 password
3 123456789
4 12345678
5 12345
6 111111
7 1234567
8 sunshine
9 qwerty
10 iloveyou
11 princess
12 admin
13 welcome
14 666666
15 abc123
16 football
17 123123
18 monkey
19 654321
20 !@#$%^&*
21 charlie
22 aa123456
23 donald
24 password1
25 qwerty123
- 增加特殊字符,将英文字符替换为特殊字符,比如
password->p@ssword! - 避开具有个人信息或者名人信息的单词
- 尽量避免多个账号使用同一个密码
- 使用密码管理器,比如
1Password,LastPass,Dashlane,Bitwarden。 - 使用双重身份验证
采取步骤保护在线身份
- 警惕公共Wi-Fi网络
- 及时更新系统、软件
- 警惕钓鱼网站、钓鱼邮件
- 为每个帐号创建不同的密码
- 使用密码管理器
5个关于密码管理器荒诞的说法
- 密码管理器不值得信赖
- 密码管理器不是100%,所以我拒绝使用
- 将我所有的密码存储在一个地方使得他们更容易获得
- 记住我所有密码比信任技术更安全。当然,这个更好,前提是你能记住所有密码
- 设置密码管理器很麻烦,相信我,花一点儿时间去设置是值得的
采取进一步措施保护
通过定期查看信用,银行卡等信息来发现是否存在泄漏。
Tips
- Python中自带的列表操作,大部分都是在原列表上操作。而不会返回产生新的列表。
Review提到的密码管理器的主密码一定要采取高强度的密码,同时要加强保管!
Share
推荐一个网站,可以检查邮箱注册帐号是否存在泄漏,链接。若想提高自己的密码的安全性,可以参考本文的Review部分
ARTS Week 5的更多相关文章
- KDE声音服务器 arts
KDE声音服务器 arts arts介绍arts是KDE的核心声音系统,支持多音频流.全双工.网络声音请求.ALSA与OSS驱动后端.JACK声音服务器后端等扩展,它既是声音服务器,也 提供一套音频软 ...
- 【ARTS】01_21_左耳听风-201900401~201900407
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_20_左耳听风-20190325~20190331
zz## ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 ...
- 【ARTS】01_19_左耳听风-20190318~20190324
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_18_左耳听风-20190311~20190317
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_17_左耳听风-20190304~20190310
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_16_左耳听风-20190225~20190303
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_15_左耳听风-20190218~20190224
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_14_左耳听风-20190211~20190217
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
- 【ARTS】01_13_左耳听风-20190204~20190210
ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...
随机推荐
- 深入 Create React App 核心概念
本文差点难产而死.因为总结的过程中,多次怀疑本文是对官方文档的直接翻译和简单诺列:同时官方文档很全面,全范围的介绍无疑加深了写作的心智负担.但在最终的梳理中,发现走出了一条与众不同的路,于是坚持分享出 ...
- ArcEngine版本管理(Version)项目总结
需求: 在ArcGIS项目中,大型的数据库都是使用ArcSDE进行连接管理.使用的数据版本(Version)都是默认版本(sde.default).这样多个人员在编辑的过程中就直接编辑的是默认版本数据 ...
- Yolo V3损失函数占个坑
https://blog.csdn.net/weixin_43384257/article/details/100974776目前来看讲的最清楚的博客 https://zhuanlan.zhihu.c ...
- Scala实践2
一.Scala基本类型和操作 1.1 基本类型 Scala的基本类型与Java基本类型相同,都是byte.short.int.long.char.string.float.double.boolea ...
- 枚举 xor
题意:输入整数n(1<=n<=3千万),有多少对整数(a,b)满足:1<=b<=a<=n,且gcd(a,b)=a XOR b.例如:n=7时,有4对:(3,2),(5,4 ...
- Spring(二)核心容器 - 简介 、BeanFactory、ApplicationContext
目录 前言 1.容器简介 2.容器的结构 2.1 BeanFactory 2.2 ApplicationContext 2.2.1 ConfigurableApplicationContext 2.2 ...
- Java中的equalsIgnoreCase()
在工作中偶然机会看到了equalsIgnoreCase()这个方法,相信大家和我一样equals()是再熟悉不过的了,但是对于equalsIgnoreCase()有点眼生(大神勿喷),所以写了这篇博客 ...
- sqlalchemy 单表增删改查
1.连接数据库,并创建session from sqlalchemy.orm import sessionmaker from sqlalchemy import create_engine engi ...
- Java入门 - 语言基础 - 08.运算符
原文地址:http://www.work100.net/training/java-operator.html 更多教程:光束云 - 免费课程 运算符 序号 文内章节 视频 1 概述 2 算术运算符 ...
- [bzoj4815] [洛谷P3700] [Cqoi2017] 小Q的表格
Description 小Q是个程序员. 作为一个年轻的程序员,小Q总是被老C欺负,老C经常把一些麻烦的任务交给小Q来处理. 每当小Q不知道如何解决时,就只好向你求助.为了完成任务,小Q需要列一个表格 ...