翻转数列python实现,求前n项和,并能输出整个数列的案例


Posted in Python onMay 03, 2020

这是刷题时遇到的一道题,题目描述:小Q定义了一种数列称为翻转数列:

给定整数n和m, 满足n能被2m整除。对于一串连续递增整数数列1, 2, 3, 4..., 每隔m个符号翻转一次, 最初符号为'-';。

例如n = 8, m = 2, 数列就是: -1, -2, +3, +4, -5, -6, +7, +8.

而n = 4, m = 1, 数列就是: -1, +2, -3, + 4.

小Q现在希望你能帮他算算前n项和为多少。

如果只需求出N项和的话,这里可以有一个简便思路,观察规律哈,比如n = 8, m = 2, 数列就是: -1, -2, +3, +4, -5, -6, +7, +8.时,

思路1:

对于一次翻转前后的两个子数组, -1, -2, 和+3, +4,+3和-1的和为2,+4和-2的和为2,总和为4,同理对后面的两个子数组求和也是4,也就是说,前后两个不同符号的子数组的和刚好是M*M,那么这样的数组有多少呢,有N/2M次,所以和为M*N/2

思路2:

对于相隔m个的两个数字数字的正好为M,这样的数字对有N/2个,所以和就为M*N/2啦~~~~是不是so easy呀

好了,python实现如下,这个是把数列输出,然后再求和,另外思路2在里面有体现哦

def isInput(m,n):
  c=n/m
  d=c%2
  if d==0:
   return True
  else:
   return False
def s(m,n):
  t=int(n/m)
  an=[]
  ai=0
  for turntime in range(1,t+1):#turntime是翻转次数
   for sublen in range(0,m):#sublen是相同符号的子序列长度
     ai=ai+1
     tt=turntime%2
     if tt==0:
      an.append(ai)
     else:
      ci=ai*(-1)
      an.append(ci)
  print(an)
  print(sum(an))
  test=[]
  for a in an:
   if a<0:
     test.append(a)
  x=len(test)
  print(m*x)#这里可以直接计算出结果
m=int(input("请输入M:"))
n=int(input('请输入N:'))

if isInput(m,n)==False:
  print('输入不合法')
else:
  s(m,n)

翻转数列python实现,求前n项和,并能输出整个数列的案例

补充知识:Python Fibonacci-无穷数列 求第n项及前n项和

Fibonacci数列,又称无穷列表,前n项和为:1,1,2,3,5,8,13,21,34,55…

他可以递归地定义为:

翻转数列python实现,求前n项和,并能输出整个数列的案例

这是一个递归关系,当n大于1时,这个数列的第n项和是前两项之和。利用递归算法可以很简单地解出其解以及前n项和。

# 分段函数 F(n)= {1 n=0; 1 n=1; F(n-1)+F(-2)  n>1}
def backValue(n):
  if n<=1:
    return 1
  return backValue(n-1)+backValue(n-2)

n = int(input("输入一个大于 0 的正整数:"))
value = [i for i in range(n)]
Fbc_list = []
for i in value:
  s = backValue(i)
  Fbc_list.append(s)

print("第%s的数为:"%n,Fbc_list[-1],"\n无穷列表为:",Fbc_list,"\n前%s项和为:"%n,sum(Fbc_list))

以上这篇翻转数列python实现,求前n项和,并能输出整个数列的案例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python中除法使用的注意事项
Aug 21 Python
Python NumPy库安装使用笔记
May 18 Python
Python OpenCV 直方图的计算与显示的方法示例
Feb 08 Python
pandas groupby 分组取每组的前几行记录方法
Apr 20 Python
Flask框架Flask-Principal基本用法实例分析
Jul 23 Python
python复制列表时[:]和[::]之间有什么区别
Oct 16 Python
解决pyttsx3无法封装的问题
Dec 24 Python
Python适配器模式代码实现解析
Aug 02 Python
Pytorch转tflite方式
May 25 Python
python中通过pip安装库文件时出现“EnvironmentError: [WinError 5] 拒绝访问”的问题及解决方案
Aug 11 Python
浅析Python的命名空间与作用域
Nov 25 Python
运行python提示no module named sklearn的解决方法
Nov 29 Python
Python定义函数实现累计求和操作
May 03 #Python
Python实现汇率转换操作
May 03 #Python
Python定时从Mysql提取数据存入Redis的实现
May 03 #Python
python函数调用,循环,列表复制实例
May 03 #Python
python轮询机制控制led实例
May 03 #Python
python 轮询执行某函数的2种方式
May 03 #Python
在Sublime Editor中配置Python环境的详细教程
May 03 #Python
You might like
PHP 文件上传进度条的两种实现方法的代码
2007/11/25 PHP
php addslashes及其他清除空格的方法是不安全的
2012/01/25 PHP
PHP多线程批量采集下载美女图片的实现代码(续)
2013/06/03 PHP
PHP获取本周第一天和最后一天示例代码
2014/02/24 PHP
PHP中4种常用的抓取网络数据方法
2015/06/04 PHP
BOOM vs RR BO5 第二场 2.14
2021/03/10 DOTA
ImageFlow可鼠标控制图片滚动
2008/01/30 Javascript
json 定义
2008/06/10 Javascript
jQuery EasyUI API 中文文档 - ComboTree组合树
2011/10/11 Javascript
jQuery中将函数赋值给变量的调用方法
2012/03/23 Javascript
检测input每次的输入是否合法遇到汉字输入就有问题
2012/05/23 Javascript
13 个JavaScript 性能提升技巧分享
2012/07/26 Javascript
jQuery.clean使用方法及思路分析
2013/01/07 Javascript
js实现仿百度汽车频道选择汽车图片展示实例
2015/05/06 Javascript
javascript密码强度校验代码(两种方法)
2015/08/10 Javascript
JQuery ztree带筛选、异步加载实例讲解
2016/02/25 Javascript
BootStrap selectpicker
2016/06/20 Javascript
浅析 NodeJs 的几种文件路径
2017/06/07 NodeJs
bootstrap+spring boot实现面包屑导航功能(前端代码)
2019/10/09 Javascript
[01:03:13]VG vs Pain 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
Python中apply函数的用法实例教程
2014/07/31 Python
Python的Django框架中settings文件的部署建议
2015/05/30 Python
python批量创建指定名称的文件夹
2019/03/21 Python
Python3之不使用第三方变量,实现交换两个变量的值
2019/06/26 Python
Python 微信爬虫完整实例【单线程与多线程】
2019/07/06 Python
如何教少儿学习Python编程
2020/07/10 Python
在Python3.74+PyCharm2020.1 x64中安装使用Kivy的详细教程
2020/08/07 Python
详解解决jupyter不能使用pytorch的问题
2021/02/18 Python
教师实习自我鉴定
2013/12/18 职场文书
农业资源与环境专业自荐信范文
2013/12/30 职场文书
《日月潭》教学反思
2014/02/28 职场文书
单位个人查摆问题及整改措施
2014/10/28 职场文书
公司员工体检通知
2015/04/21 职场文书
关于车尾的标语大全
2015/08/11 职场文书
2015年十月一日放假通知
2015/08/18 职场文书
《乘法分配律》教学反思
2016/02/24 职场文书