格式化输出,基本运算符,if判断

1. 格式化输出的三种方式

在程序中,需要将输出信息打印成固定的格式,这时候就需要格式化输出。

1.1 占位符

这种格式化输出方式与C语言中的类似,使用%s占位,再将后面%号后括号内的变量依次传给占位符,具体使用方法如下:

name = 'Zhao Jun'
age = 18
height = 185
print('My name is %s, I am %s years old, my height is %s' %(name, age, height))

1.2 format格式化

占位符方式的变形,使用{}作为占位符,.format代替了%,括号内的值依次传给占位符,另外,如果{}内传入索引,传参顺序可不按括号内顺序,具体使用方法如下:

name = 'Zhao Jun'
age = 18
height = 185
print('My name is {}, I am {} years old, my height is {}'.format(name,  age, height))
print('My name is {1}, I am {0} years old, my height is {2}'.format(age, name, height))

1.3 f-string格式化

python3.6新增的方式,使用f'str'的格式,使用{}占位,要传入的变量直接写在{}内,具体用法如下:

name = 'Zhao Jun'
age = 18
height = 185
print('My name is {name}, I am {age} years old, my height is {height}')

另外,使用{}的两种方式可以使用例如{:2f}(format格式化),{height:2f}(f-string格式化)的方式来控制变量的输出效果。

2. 基本运算符

2.1 算数运算符

常用算术运算符使用方法如下:

x = 5
y = 2
a = x + y  # 加法运算
b = x - y  # 减法运算
c = x * y  # 乘法运算
d = x / y  # 除法运算
e = x // y  # 取整运算
f = x % y  # 取余运算
g = x ** y  # 幂运算

2.2 比较运算符

比较运算返回bool值,常用比较运算符使用方法如下:

x = 5
y = 2
print(x > y)  # True
print(x < y)  # False
print(x == y)  #False
print(x >= y)  # True
print(x <= y)  # False
print(x != y)  # True

2.3 赋值运算符

赋值运算符使用方法如下:

x = 5
y = 2
x += y  # x = x + y
X -= y  # x = x - y
x *= y  # x = x * y
x /= y  # x = x / y
x //= y  # x = x // y
x %= y  # x = x % y
x **= y  # x = x ** y

2.4 逻辑运算符

逻辑运算符返回bool值,使用方法如下:

a = 5
b = 2
print(a == 2 and b > 1)  # 与运算,同时为真才为真,False
print(a == 2 or b > 1)  # 或运算,同时为假才为假,True
print(not b)  # 非运算,取反,False

2.5 身份运算

身份运算符is,判断两个变量的内存地址是否一样,返回bool值,具体用法如下:

a = 5
b = 10
c = 5
print(a is b)  # False
print(a is c)  # True,小整数池的原因

2.6 运算符优先级

python运算符的优先级如下图,只做了解,使用时可用括号提高优先级。

image

3. 流程控制之if判断

3.1 语法

3.1.1 if语句

最简单的if语句如下:

<代码块1>          # 执行代码块1
if <条件>:         # 如果满足条件,运行代码块2
 <代码块2>
<代码块3>          # 不管代码块2是否执行,最后都执行代码块3

3.1.2 if...else

<代码块1>          # 执行代码块1
if <条件>:         # 如果满足条件,运行代码块2
    <代码块2>
else:
    <代码块4>      # 如果不满足条件,运行代码块4
<代码块3>          # 最后执行代码块3

3.1.3 if...elif...else

<代码块1>          # 执行代码块1
if <条件1>:         # 如果满足条件1,运行代码块2
    <代码块2>
elif <条件2>:      # 如果条件1不满足,条件2满足,运行代码块5
    <代码块5>
...
elif <条件n>:      # 如果条件1-(n-1)都不满足,条件n满足,运行代码块n
    <代码块n>
else:
    <代码块4>      # 如果所有条件都不满足,运行代码块4
<代码块3>          # 最后执行代码块3

3.2 if的嵌套

if语句里可嵌套if语句,具体方法可参考本文3.3中的例子。

3.3 if...else语句的练习

以下代码时根据LeetCode上的罗马数字转整数的题目要求写的,使用最笨的办法,挨个判断接收字符串中的元素,判断是否增加计数值,对if...else语句的练习是一个很好的例子。

"""
罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。

字符          数值
I             1
V             5
X             10
L             50
C             100
D             500
M             1000
例如, 罗马数字 2 写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做  XXVII, 即为 XX + V + II 。

通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:

I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。 
C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。
给定一个罗马数字,将其转换成整数。输入确保在 1 到 3999 的范围内。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/roman-to-integer
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
"""

s = "MMMCDXC"
result = 0

for index in range(len(s)):
    if s[index] == 'M':
        if s[index - 1] == 'C' and index > 0:
            result += 800
        else:
            result += 1000

    elif s[index] == 'D':
        if s[index - 1] == 'C' and index > 0:
            result += 300
        else:
            result += 500

    elif s[index] == 'C':
        if s[index - 1] == 'X' and index > 0:
            result += 80
        else:
            result += 100

    elif s[index] == 'L':
        if s[index - 1] == 'X' and index > 0:
            result += 30
        else:
            result += 50

    elif s[index] == 'X':
        if s[index - 1] == 'I' and index > 0:
            result += 8
        else:
            result += 10

    elif s[index] == 'V':
        if s[index - 1] == 'I' and index > 0:
            result += 3
        else:
            result += 5

    else:
        result += 1

print(result)

大家可自行更改s的值来转换,本段代码的执行结果为:

3490

你可能感兴趣的:(格式化输出,基本运算符,if判断)