total_num=raw_input() #输入总人数
n=int(total_num) #记录队尾人编号
list_people=[]
for i in range(0,int(total_num)): #将所有的人进行入队
list_people.append(i)
chudui_list=[] #依次将出队的人,按顺序加入出队列表
index=0
for j in range(0,int(total_num)):
index = (index+4)%len(list_people) #因为每报数5的人出队,所以一开始指向索引为0,加4即间隔为4,刚好索引为0,到索引为4(中间跳过5次),对未出队的人数取余
chudui_list.append(list_people[index]) #记录报数为5的人,加入已出队的列表
# print list_people[index]
list_people.remove(list_people[index]) #将报数为5的人,从未出队列表中删除
# print list_people[index]
print chudui_list.index(n-1)+1 #打印队尾出队的顺序(即队尾是第几个出队的),n-1是因为,开始入队的人员编号是从0开始,而不是从1开始,最后index+1是因为,index从0开始计数
第二题
class Solution(object):
def lengthOfLongestSubstring(self, s):
"""
:type s: str
:rtype: int
"""
# 存储历史循环中最长的子串长度
max_len = 0
# 判断传入的字符串是否为空
if s is None or len(s) == 0:
return max_len
# 定义一个字典,存储不重复的字符和字符所在的下标
str_dict = {}
# 存储每次循环中最长的子串长度
one_max = 0
# 记录最近重复字符所在的位置+1
start = 0
for i in range(len(s)):
# 判断当前字符是否在字典中和当前字符的下标是否大于等于最近重复字符的所在位置
if s[i] in str_dict and str_dict[s[i]] >= start:
# 记录当前字符的值+1
start = str_dict[s[i]] + 1
# 在此次循环中,最大的不重复子串的长度
one_max = i - start + 1
# 把当前位置覆盖字典中的位置
str_dict[s[i]] = i
# 比较此次循环的最大不重复子串长度和历史循环最大不重复子串长度
max_len = max(max_len, one_max)
return max_len
if __name__ == '__main__':
sol = Solution()
print(sol.lengthOfLongestSubstring("bbbbb"))
print(sol.lengthOfLongestSubstring("eeydgwdykpv"))
print(sol.lengthOfLongestSubstring("pwwkew"))
print(sol.lengthOfLongestSubstring("abcabcbb"))