python2.7练习小例子(五)

    5):题目:输入三个整数x,y,z,请把这三个数由小到大输出。

    程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小。

    程序源代码:

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-

l = []
for i in range(3):
    x = int(raw_input('integer:\n'))
    l.append(x)
l.sort()
print l

    以上实例输出结果为:

 

integer:
8
integer:
5
integer:
6
[5, 6, 8]

    其他参考解法:

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-

x = int(raw_input("x:"))
y = int(raw_input("y:"))
z = int(raw_input("z:"))
a = {"x":x,"y":y,"z":z}
print '--------分割线--------'
for w in sorted(a, key=a.get):
    print w, a[w]

    输出结果为:

 

x:5
y:2
z:8
--------分割线--------
y 2
x 5
z 8

    

#!/usr/bin/python
# -*- coding: UTF-8 -*-

a=[1,3,5,2,4,5,7]

n=len(a)

for i in range(0,n):
  for j in range(i,n) :
     if (a[i] >= a[j] ):
         tmp =a[i]
         a[i]=a[j]
         a[j]=tmp

print a

    

#!/usr/bin/python
# -*- coding: UTF-8 -*-

x= raw_input("int1:")
y= raw_input("int2:")
Max = max(x,y)
Min = min(x,y)
z= raw_input("int3:")
if z > Max :
    print Min,Max,z
elif z < Min :
    print z,Min,Max
else :
    print Min,z,Max

    Python3.x 版本下使用利用冒泡排序方法:

 

#!/usr/bin/env python3

# 利用冒泡排序方法
def Sort(list):
    n = len(list)
    for i in range(1, n):
        # 一次次的将最大的学出来
        for j in range(1, n - i + 1):
            if list[j - 1] > list[j]:
                list[j - 1], list[j] = list[j], list[j - 1]
            # 打印排序过程
            print(list)
    for i in range(0, n):
        print(list[i])

# 读入数据
def inputData():
    list_first = []
    while True:
        a = input("please input num:".strip())
        if len(a) == 0:
            return list_first
        else:
            list_first.append(int(a))

if __name__ == '__main__':
    lt = inputData()
    print(lt)
    Sort(lt)

    使用 列表 sort=,可接受参数 reverse,默认为布尔值 false,按升序排序,设置为 true 则按降序排序:

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-

x = int(input('x='))
y = int(input('y='))
z = int(input('z='))
num = [x, y, z]
num.sort()          # 对列表进行升序排序
print '这三个数由小到大的顺序为:',num
rnum = [x, y, z]                  # 对列表进行降序排序
rnum.sort(reverse=True)
print '这三个数由大到小的顺序为:',rnum

    

#!/usr/bin/env python
#coding:utf-8

D=raw_input("请输入三个数字,格式如 'a,b,c':")
li=D.split(",")
li2=[int(i) for i in li]
li2.sort()
print li2

    对输入类型进行了控制,如果输入错误,就提示用户,让用户再次输入,直到正确输入整数为止:

 

#!/usr/bin/env python
#coding:utf-8
#输入三个整数x,y,z,请把这三个数由小到大输出。
while 1:
    try:
        x = int(input("plz input x: "))
        y = int(input("plz input y: "))
        z = int(input("plz input z: "))
        list1 = [x, y, z]
        print(sorted(list1))
        break
    except:
        print("请输入整数")

    

#! /usr/bin/python
# -*- coding:UTF-8 -*-
a = int(raw_input("请输入:"))
b = int(raw_input("请输入:"))
c = int(raw_input("请输入:"))
if a>b and a>c:
    x = a
    a = c
elif b>a and b>c:
    x = b
    b = c
else:
    x = c
if a>b:
    print b,a,x
else:
    print a,b,x

    

#!/usr/bin/python
# -*- coding: UTF-8 -*-

x = int(raw_input('x->'))
y = int(raw_input('y->'))
z = int(raw_input('z->'))
arr = [x,y,z]
for i in range (0,3):
    for o in range (0,3):
        for p in range (0,3):
            if arr[i] > arr[o] > arr[p]:
                print arr[i],arr[o],arr[p]

    

# -*- coding: utf-8 -*-

import numpy as np
x=int(input('请输入一个整数:\n'))
y=int(input('请输入一个整数:\n'))
z=int(input('请输入一个整数:\n'))
l = [x,y,z]
for i in range(len(l)):
    a = np.argmin(l)
    print(l[a])
    del l[a]

    下例更简单,Python2.x 与 Python3.x 均可使用:

 

# -*- coding: utf-8 -*-
x=int(input('请输入一个整数:\n'))
y=int(input('请输入一个整数:\n'))
z=int(input('请输入一个整数:\n'))

if(x > y):
    x,y = y,x;
if(y > z):
    y,z = z,y

print((x,y,z));

    下例更通用:

 

# -*- coding: utf-8 -*-
elements=(4,3,5,2,6,1,7);
print("正序排列:{}".format(sorted(elements)));
print("倒序排列:{}".format(list(reversed(sorted(elements)))));

    python3的实例:

 

print(sorted([int(input("enter a integer: ")) for x in range(3)]))

    冒泡算法:

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-

#冒泡排序
a = [int(i) for i in raw_input("请输入:").split()]
m = len(a)
while m!=1:
    for i in range(m-1):
        if a[i]>a[i+1]:
            x = a[i]
            a[i] = a[i+1]
            a[i+1] = x
    m -= 1
print a

    列表sort:

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-

l = [int(i) for i in raw_input("请输入: ").split()]
l.sort()
print l

    看过这么些个例子,诸君有何感想???我的感觉就是,遇到问题,优先考虑内置函数,再来是算法,最后就是通常意义上的自己写一个函数了。。。

    如果感觉不错的话,请多多点赞支持哦。。。

  原文链接:https://blog.csdn.net/luyaran/article/details/80017404

posted @ 2018-04-25 11:38  luyaran  阅读(473)  评论(0编辑  收藏  举报