关注
# -*-coding:utf-8 -*-
import sys
import numpy as np
from collections import OrderedDict
import collections
def print_lists(lists):
"""
打印二维列表
:param lists: List[List[int]]
:return: None
"""
for list in lists:
for i, x in enumerate(list):
print(x, end=' ')
print(end='\n')
# def fib(n, a, x):
# list = list()
# list.append(n)
# list.append(a)
# b = n + a
# list.append(b)
# while b <= max:
# b = n + a
# list.append(b)
# n, a = a, b
#
# return list
def fib(n , a, max):
list = []
b = 0
list.append(n)
list.append(a)
while b <= max:
b = n + a
n, a = a, b
list.append(b)
# a, b = b, a + b
# list.append(b)
# if max in list:
# weizhi = list.index(max)
return list
def solution(x):
ret = []
array = []
if x < 3:
return
if x == 3:
list1 = fib(1, 1, x)
list2 = fib(1, 2, x)
list3 = fib(2, 1, x)
array.append(list1)
array.append(list2)
array.append(list3)
else:
list1 = fib(1, 1, x)
list2 = fib(1, 2, x)
list3 = fib(2, 1, x)
array.append(list1)
array.append(list2)
array.append(list3)
for i in range(4, x+1, 1):
if i%2 == 0:
list1 = []
a = int(i/2)
list1 = fib(a, a, x)
array.append(list1)
else:
n = int(i/2)
a = int(i/2)+1
list1 = fib(n, a, x)
array.append(list1)
list1 = fib(a, n, x)
array.append(list1)
hash = OrderedDict()
print_lists(array)
for list in array:
if x in list:
weizhi = list.index(x) + 1
hash[weizhi] = hash.get(weizhi, 0) + 1
hash = OrderedDict(sorted(hash.items(), key=lambda x: x[0], reverse=False))
return hash
if __name__ == "__main__":
# 读取第一行的n
ret = []
for i in range(1):
x = int(sys.stdin.readline().strip())
# print(x)
ret_hash = solution(x)
for i, j in ret_hash.items():
ret.append([i, j])
print_lists(ret) 你看看我这个答案可以没,我自己测试是没问题,不过提示数组越界了。
查看原帖
点赞 2
相关推荐
牛客热帖
更多
正在热议
更多
# 摸鱼被leader发现了怎么办 #
73029次浏览 419人参与
# 工作后明白的那些道理 #
29095次浏览 296人参与
# 工作后,你落下了哪些病根 #
1114次浏览 28人参与
# 电网求职进展汇总 #
33322次浏览 90人参与
# 你学到的“最没用”的职场技能是 #
963次浏览 27人参与
# 七夕节你打算怎么过? #
69987次浏览 806人参与
# 国央企笔面经互助 #
172341次浏览 1211人参与
# 业务面应该做哪些准备 #
80290次浏览 830人参与
# 满帮集团求职进展汇总 #
13223次浏览 95人参与
# 拼多多求职进展汇总 #
797608次浏览 6452人参与
# 上班到公司第一件事做什么? #
113506次浏览 780人参与
# 职场破防瞬间 #
352606次浏览 2827人参与
# 工作两年想退休了 #
207818次浏览 1838人参与
# 视觉/交互/设计招聘信息汇总 #
24377次浏览 634人参与
# 产品人求职现状 #
299031次浏览 2363人参与
# 如果可以选,你最想从事什么工作 #
672103次浏览 4848人参与
# 满分简历要如何准备? #
249490次浏览 2959人参与
# 通信和硬件还有转码的必要吗 #
80041次浏览 584人参与
# 你见过最离谱的招聘要求是什么? #
245345次浏览 1691人参与
# 学历对求职的影响 #
573317次浏览 3974人参与
