翻转数列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分割列表(list)的方法示例
May 07 Python
Linux系统(CentOS)下python2.7.10安装
Sep 26 Python
使用 Visual Studio Code(VSCode)搭建简单的Python+Django开发环境的方法步骤
Dec 17 Python
python实现矩阵打印
Mar 02 Python
django使用haystack调用Elasticsearch实现索引搜索
Jul 24 Python
Python中的 sort 和 sorted的用法与区别
Aug 10 Python
Python字节单位转换实例
Dec 05 Python
Python表达式的优先级详解
Feb 18 Python
python名片管理系统开发
Jun 18 Python
Python Serial串口基本操作(收发数据)
Nov 06 Python
python基于爬虫+django,打造个性化API接口
Jan 21 Python
Opencv实现二维直方图的计算及绘制
Jul 21 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 按位与或 (^ 、&amp;)
2013/06/21 PHP
php网站地图生成类示例
2014/01/13 PHP
PHP上传文件时自动分配路径的方法
2015/01/09 PHP
在Yii2特定页面如何禁用调试工具栏Debug Toolbar详解
2017/08/07 PHP
PHP获取数据库表中的数据插入新的表再原删除数据方法
2018/10/12 PHP
使一个函数作为另外一个函数的参数来运行的javascript代码
2007/08/13 Javascript
一个JS函数搞定网页标题(title)闪动效果
2014/05/13 Javascript
jquery转盘抽奖功能实现
2015/11/13 Javascript
微信端开发--登录小程序步骤
2017/01/11 Javascript
原生js实现简单的链式操作
2017/07/04 Javascript
AngularJS通过ng-Img-Crop实现头像截取的示例
2017/08/17 Javascript
详解js的作用域、预解析机制
2018/02/05 Javascript
JavaScript文本特效实例小结【3个示例】
2018/12/22 Javascript
深入理解vue-class-component源码阅读
2019/02/18 Javascript
使用nodejs分离html文件里的js和css详解
2019/04/12 NodeJs
仿vue-cli搭建属于自己的脚手架的方法步骤
2019/04/17 Javascript
微信小程序从注册账号到上架(图文详解)
2019/07/17 Javascript
解决React在安装antd之后出现的Can't resolve './locale'问题(推荐)
2020/05/03 Javascript
简单了解常用的JavaScript 库
2020/07/16 Javascript
[01:02:00]DOTA2-DPC中国联赛 正赛 Elephant vs IG BO3 第三场 1月24日
2021/03/11 DOTA
Python中将字典转换为XML以及相关的命名空间解析
2015/10/15 Python
最近Python有点火? 给你7个学习它的理由!
2017/06/26 Python
pandas string转dataframe的方法
2018/04/11 Python
Python实现的knn算法示例
2018/06/14 Python
Django管理员账号和密码忘记的完美解决方法
2018/12/06 Python
java判断三位数的实例讲解
2019/06/10 Python
PyQt5 加载图片和文本文件的实例
2019/06/14 Python
Python API len函数操作过程解析
2020/03/05 Python
解决HTML5手机端页面缩放的问题
2017/10/27 HTML / CSS
国外的一些J2EE面试题一
2012/10/13 面试题
个人合伙协议书范本
2014/10/14 职场文书
2014年党的群众路线学习心得体会
2014/11/05 职场文书
2015年先进个人自荐书
2015/03/24 职场文书
撤诉申请怎么写
2015/05/19 职场文书
大学生自我鉴定怎么写
2019/05/07 职场文书
Python机器学习应用之工业蒸汽数据分析篇详解
2022/01/18 Python