1,给定一组数据,将奇数进行从小到大排序,偶数在原位置不变

  例: 原数据:[5, 3, 2, 8, 1, 4]  

    排序后:[5, 3, 2, 8, 1, 4]

    若数组为空,则返回空数组。

  代码如下:

 方法一:
def sort_array(source_array):
# Return a sorted array.
#首先判断数组是否为空
if not source_array : return source_array
length = len(source_array) # 求数组的长度
for i in range(length): # 进行循环
if source_array[i] % 2 == 0: # 若为偶数,则跳过
continue
for j in range(i+1,length): # 两层循环,进行排序
if source_array[j] % 2 == 0: # 若为偶数,则跳过
continue
if source_array[i] > source_array[j]: # 排序
t = source_array[i]
source_array[i] = source_array[j]
source_array[j] = t
return source_array # 返回排序后的数组
方法二(高级版,临摹大佬的):
def sort_array(arr):
odds = sorted((x for x in arr if x%2 != 0), reverse=True)
# 当x为奇数时,挑选出来,进行从大到小排序
# sorted默认为从小到大,加上reverser表示反转的意思
return [x if x%2==0 else odds.pop() for x in arr]
# 返回数组,odds.pop()为删除最后一个数据并返回

2,返回最大值和最小值

给定一个字符串,“1 2 2 3”,数字中间由空格隔开,保证字符串最少有一个字符,返回字符串中字符数值的最大值,最小值

最大值在前,最小值在后,中间同样有空格相隔开

例:原字符串:‘1 2 3 4’,‘25 8 9 -989 ’

  返回值:‘4 1’   ,  ‘25 -989’

代码如下

方法一:
def high_and_low(numbers):
# ...
numbers = numbers.split(' ')
# 将字符串分隔开并转化为列表,每一个字符为列表的一项
num_max = int(numbers[0]) # 给num_max赋值列表的第一项的数值形式
num_min = int(numbers[0])
for i in numbers: # 进行循环,求出最大值和最小值
if num_max < int(i):
num_max = int(i)
if num_min > int(i):
num_min = int(i)
return '%d %d'%(num_max,num_min) # 进行格式化返回
方法二(高级版,临摹大佬):
def high_and_low(numbers):
n = map(int,numbers.split(' ')) # 利用map函数产生两个迭代器
m = map(int,numbers.split(' '))
return str(max(n)) + ' ' + str(min(m)) # 进行字符串拼接

3,元音数

给定一个字符串,字符串由小写字母和空格组成,求出元音字母的个数,并返回。

元音字母:a,e,i,o,u

例:参数:'abcdefg'

  返回值:

代码如下:

方法一:
def getCount(inputStr):
num_vowels = 0 # 给定初始值
# your code here
vowel = 'aeiou' # 赋值一个包含元音字母的字符串
for i in inputStr: # 进行循环
if i in vowel: # 判断字符是否为元音字符
num_vowels += 1
return num_vowels
方法二(临摹版本,没有搞明白):
def getCount(inputStr):
return sum(1 for let in inputStr if let in 'aeiou')

4,序列和

给定三个数字,分别代表起始数字,结束数字,步长,求出序列的和值。

如果起始数字大于结束数字,则返回零

例:参数:(2, 6, 2),(1, 5, 3),(10, 5, 3)

  返回值:12,5,0

代码如下:

# 方法一:
def sequence_sum(begin_number, end_number, step):
#your code here
if begin_number > end_number : # 判断起始数字是否大于结束数字
return 0
sum = 0
while begin_number <= end_number: # 进行循环
sum += begin_number # 求和
begin_number += step
return sum
# 方法二:
def sequence_sum(begin_number, end_number, step):
return sum(range(begin_number,end_number+1,step)) # 运用内置函数求和
												

Python简单试题2的更多相关文章

  1. python简单试题4

    ( ps : 题目中用到的一些random函数在最后末尾处有介绍)  1,在屏幕上显示跑马灯文字 import os # 调用os模块 import time # 调用时间模块 def main(): ...

  2. Python简单试题

    1,相乘次数 题目要求描述: 一个整数每一位上的数字相乘,判断是否为个位数,若是则程序结束 ,不是则继续相乘,要求返回相乘次数. 例:39 > 3*9=27 > 2*7=14 > 1 ...

  3. Python简单试题3

    1,水仙花数 水仙花数是指一个 3 位数,它的每个位上的数字的 3次幂之和等于它本身 (例如:1^3 + 5^3+ 3^3 = 153)  代码如下: 方法一: for i in range(100, ...

  4. python简单面试题

    在这个即将进入金9银10的跳槽季节的时候,肯定需要一波面试题了,安静总结了一些经常遇到的python面试题,让我们一起撸起来. python面试题 1.求出1-100之间的和 # coidng:utf ...

  5. python公司面试题集锦 python面试题大全

    问题一:以下的代码的输出将是什么? 说出你的答案并解释. class Parent(object): x = 1 class Child1(Parent): pass class Child2(Par ...

  6. 7.22 python面试题

    2018-7-22 16:32:24 把面试题敲完了,,好强悍! Python 10期考试题 1.常用字符串格式化有那些?并说明他们的区别 # format 直接调用函数 # %s 语法塘 # %r ...

  7. Python面试题整理-更新中

    几个链接: 编程零基础应当如何开始学习 Python ? - 路人甲的回答 网易云课堂上有哪些值得推荐的 Python 教程? - 路人甲的回答 怎么用最短时间高效而踏实地学习 Python? - 路 ...

  8. python 面试题4

    Python面试题 基础篇 分类: Python2014-08-08 13:15 2071人阅读 评论(0) 收藏 举报 最近,整理了一些python常见的面试题目,语言是一种工具,但是多角度的了解工 ...

  9. 很全的 Python 面试题

    很全的 Python 面试题 Python语言特性 1 Python的函数参数传递 看两个例子:           Python   1 2 3 4 5 a = 1 def fun(a):      ...

随机推荐

  1. Netty(2)Echo

    上节介绍的是discard协议,即不给客户端返回消息.本节主要说下,echo协议,即服务端收到消息后原样返回给客户端. 为了实现此需求,只需要在DiscardServerHandler中重写chann ...

  2. Spring创建对象的几种方法

    一.通过构造器 无参构造器 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=" ...

  3. (转)通过MySQL复制线程SQL_Thread加快增量恢复binlog

    数据回档常常是使用全量备份+binlog增量实现的.而数据量很大的情况下,增量恢复binlog一直是一个苦恼的问题,因为恢复binlog速度十分慢,并且容易出错. 恢复binlog文件一般有两种方法: ...

  4. SQLServer数据库表字段超长,找到超长字段脚本

    平时开发系统时偶尔会遇到数据超长导致往数据库中保存时出错. 使用下边的脚本可以方便的找出超长的字段. 1.通过正式表创建临时表,修改临时表中varchar.nvarchar的长度为max ); ); ...

  5. Java实现的断点续传功能

    代码中已经加入了注释,需要的朋友可以直接参考代码中的注释.下面直接上功能实现的主要代码: import java.io.File; import java.io.FileNotFoundExcepti ...

  6. 阿里开发搜索(OpenSearch)的学习与使用

    概述: 开放搜索(OpenSearch)是一款结构化数据搜索托管服务,为移动应用开发者和网站站长提供简单.高效.稳定.低成本和可扩展的搜索解决方案. OpenSearch基于阿里巴巴自主研发的大规模分 ...

  7. JAVA-Web05

    1 HTTP协议特点   1)客户端->服务端(请求request)有三部份 a)请求行 b)请求头 c)请求的内容,如果没有,就是空白字符     2)服务端->客户端(响应respon ...

  8. ES6, Angular,React和ABAP中的String Template(字符串模板)

    String Template(字符串模板)在很多编程语言和框架中都支持,是一个很有用的特性.本文将Jerry工作中使用到的String Template的特性做一个总结. ES6 阮一峰老师有一个专 ...

  9. UVA 11491 Erasing and Winning 奖品的价值 (贪心)

    题意:给你一个n位整数,让你删掉d个数字,剩下的数字要尽量大. 题解:因为最后数字位数是确定的,而且低位数字对答案的贡献是一定不及高位数字的,所以优先选择选最大且最靠左边的数字,但是有一个限制,选完这 ...

  10. UVA11212 EditingaBook ( IDA*搜索)

    首先说说IDS,就DFS限定一个层数上限maxd,如果在maxd范围内没有找到解,就增加maxd,继续搜索. 当访问到当前结点u时,估计还要搜索h(u)层,如果h(u)+当前层数d>maxd的时 ...