升序来做这个题
比如123就变成321 需要比对3个数
这不是比对2个数。a和b比对 我们可以直接写
if a>b:
print(ab)
else
print(ba)
但是现在是3个数abc
如果进行if比对呢
if a > b >c:
print(a,b,c)
elif a < b >c:
print(bca)
…
简洁的代码变成了复杂的代码段。
我们改改。利用类和对象来试一下
其实我觉得类和对象也是建立在选择基础上的。
如果选择基础没有做好类和对象的方便就不能体现
如果按abc排列
abc acb bac bca cba cab 是6重组合
但这个是没有带大小组合的
a大于b大于c
比如a大于b但小于c呢???
cab对吧
那应该让计算机如何认别呢
if c>a>b:
321
a,b,c =2,1,3
elif c>b>a:
321
a,b,c = 1,2,3
elif a>b>c:
321
a,b,c =3,2,1
elif a>c>b:
321
a,b,c = 3,1,2
elif c>a>b:
321
a,b,c =2,1,3
elif b>a>c:
3 2 1
a,b,c = 2,3,1
elif b>c>a:
321
a,b,c = 1,3,2
如果不改变abc的位置呢
a>b>c
3,2,1
a<b<c
1,2,3
a>b<c
??3,1,2 or 2,1,3
a<b>c
??1,3,2 or 2,3,1
??这是我发现的这些对比里最要命的
a 小于b。b大于c 请问a和c到底是谁?
也许用数学的办法解决??可我不会数学题。这可怎么办
a小于b那么b一定是3或2. 然后c小于b那么c应该是2
1,3,2哇塞这个我自认为的难题自己解决了,真的我真的把这个当成主题了都。但是没想到这么快解决。
看来我不习惯自己进步太快。但是如果不进步快,我就会倒退 。所以应该继续前进。
在不改变abc位置的方式下,我们获得了4种而不是变化abc位置的6种排列。
看看缺的是哪两种
2,1,3
2,3,1
原来不改变abc位置会得出这样两个结果
a>b<c
??3,1,2 or 2,1,3
a<b>c
??1,3,2 or 2,3,1
所以通过不改变a,b,c的位置我们的到了少于自由变化位置的2个对比项
看来我可以省略很多代码了
正常根据第4章所学写的代码
in_integer = 123
int_a = in_integer // 100
int_b = in_integer % 100 // 10
int_c = in_integer % 100 % 10
print('in_integer // 100 is ', int_a)
print('in_integer % 100 // 10 is ', int_b)
print('in_integer % 100 % 10 is ', int_c)
利用第7章知识写的代码
class int_integer:
def __init__(self, num):
self.num = num
def get_integer_a(self):
return self.num // 100
def get_integer_b(self):
return self.num % 100 // 10
def get_integer_c(self):
return self.num % 100 % 10
问题
😩我发现看来还是应该是6个条件
a>b<c
??3,1,2 or 2,1,3
a<b>c
??1,3,2 or 2,3,1
3, 1, 2
其实c,a,b
2, 1, 3
b,a,c
但二者都有共同点头一位大于b,b小于后一位
看来没法省了,还得继续
用第4章代码写
if a > b > c:
print('a > b > c', a, b, c)
elif a < b < c:
print('a < b < c', c, b, a)
elif a > b < c:
print('a > b < c', b, a, c)
elif a < b > c:
print('a < b > c', b, c, a)
elif c > b < a:
print('a > b < c', a, c, b)
elif c < b > a:
print('a < b > c', b, a, c)
结果
用第7章的概念写
class analyst:
def __init__(self, a, b, c):
self.a = a
self.b = b
self.c = c
def get_analysts(self):
if self.a > self.b > self.c:
print('a > b > c is result ', self.a, self.b, self.c)
elif self.a < self.b < self.c:
print('a < b < c is result ', self.c, self.b, self.a)
elif self.a > self.b < self.c:
print('a > b < c is result ', self.b, self.a, self.c)
elif self.a < self.b > self.c:
print('a < b > c is result ', self.b, self.c, self.a)
elif self.c > self.b < self.a:
print('a > b < c is result ', self.a, self.c, self.b)
elif self.c < self.b > self.a:
print('a < b > c is result ', self.b, self.a, self.c)
完成代码
class int_integer:
def __init__(self, num):
self.num = num
def get_integer_a(self):
return self.num // 100
def get_integer_b(self):
return self.num % 100 // 10
def get_integer_c(self):
return self.num % 100 % 10
class analyst:
def __init__(self, a, b, c):
self.a = a
self.b = b
self.c = c
def get_analysts(self):
if self.a > self.b > self.c:
print('a > b > c is result ', self.a, self.b, self.c)
elif self.a < self.b < self.c:
print('a < b < c is result ', self.c, self.b, self.a)
elif self.a > self.b < self.c:
print('a > b < c is result ', self.b, self.a, self.c)
elif self.a < self.b > self.c:
print('a < b > c is result ', self.b, self.c, self.a)
elif self.c > self.b < self.a:
print('a > b < c is result ', self.a, self.c, self.b)
elif self.c < self.b > self.a:
print('a < b > c is result ', self.b, self.a, self.c)
int_num = int_integer(123)
num1 = int_num.get_integer_a()
num2 = int_num.get_integer_b()
num3 = int_num.get_integer_c()
integer_com = analyst(num1,num2,num3)
integer_com.get_analysts()