这里是你的通告内容

春生

Be humble, communicate clearly, and respect others.

Go语言基础之运算符

Go语言基础之运算符

运算符

运算符用于在程序运行时执行数学或逻辑运算。

Go语言中内置的运算符有:

  1. 算术运算符
  2. 关系运算符
  3. 逻辑运算符
  4. 位运算符
  5. 赋值运算符

算术运算符

运算符 描述
+ 相加
- 相减
* 相乘
/ 相除
% 求余
++ (单独的语句) 自增
_ _ (单独的语句) 自减

注意: ++(自增)和--(自减)在Go语言中是单独的语句,并不是运算符。

代码:

package main

import "fmt"
var n1 = 19
var n2 = 3
func main()  {
	fmt.Println(n1 + n2) // +  结果: 21
	fmt.Println(n1 - n2) // -  结果: 16
	fmt.Println(n1 * n2) // *  结果: 57
	fmt.Println(n1 / n2) // /  结果: 6
	// 取余
	fmt.Println(n1 % n2) // % 结果: 1
	// ++
	n1++
	fmt.Println(n1) // 自增一次  结果: 20
	// --
	n2--
	fmt.Println(n2) //自减一次  结果: 2
}

关系运算符

运算符 描述
== 检查两个值是否相等,如果相等返回 True 否则返回 False。
!= 检查两个值是否不相等,如果不相等返回 True 否则返回 False。
> 检查左边值是否大于右边值,如果是返回 True 否则返回 False。
>= 检查左边值是否大于等于右边值,如果是返回 True 否则返回 False。
< 检查左边值是否小于右边值,如果是返回 True 否则返回 False。
<= 检查左边值是否小于等于右边值,如果是返回 True 否则返回 False。

代码:

package main

import "fmt"

func RelationalOperator()  {
	var n1 = 19
	var n2 = 3
	fmt.Println(n1 == n2) // 结果:false
	fmt.Println(n1 != n2) // 结果: true
	fmt.Println(n1 > n2)  // 结果: true
	fmt.Println(n1 < n2)  // 结果: false
	fmt.Println(n1 >= n2) // 结果: true
	fmt.Println(n1 <= n2) // 结果: fales

}

func main()  {
	RelationalOperator()
}

逻辑运算符

运算符 描述
&& 逻辑 AND 运算符。 如果两边的操作数都是 True,则为 True,否则为 False。
|| 逻辑 OR 运算符。 如果两边的操作数有一个 True,则为 True,否则为 False。
! 逻辑 NOT 运算符。 如果条件为 True,则为 False,否则为 True。

代码:

package main

import "fmt"

func LogicalOperators()  {
	var a = true
	var b = false
	// and 两边都为真 则为真 否则就为 假
	fmt.Println(a && b)   // 结果: false
	// or 只要有一边为真 就为真 否则为 假
	fmt.Println(a || b) // 结果:true
	// not 取非如果为真就为假 取非为假就为真
	fmt.Println(!a)   // a是 true 结果: false
	fmt.Println(!b)   // bs是 false 结果: true
}


func main()  {
	LogicalOperators()

}

位运算符

位运算符对整数在内存中的二进制进行操作.

运算符 描述
& 参与运算的两数各对应的二进位相与。 (两位均为1才为1)
| 参与运算的两数各对应的二进位相或。 (两位有一个为1就为1)
^ 参与运算的两数各对应的二进位相异或,当两对应的二进位相异时,结果为1。 (两位不一样则为1)
<< 左移n位就是乘以2的n次方。 “a<<b”是把a的各二进位全部左移b位,高位丢弃,低位补0。
>> 右移n位就是除以2的n次方。 “a>>b”是把a的各二进位全部右移b位。

代码:

package main

import "fmt"

func main()  {
	fmt.Printf("13的二进制 ————> %b \n",13) // 结果:1101
	fmt.Printf("13的二进制 ————> %b \n",3) // 结果:11
	// & (两位均为1才为1)  0001
	fmt.Println(13 & 3) // 结果 1
	// | (两位只要有1则为1)   1111
	fmt.Println(13 | 3) // 结果 15
	// ^ (两位不一样 则为1)  1110
	fmt.Println(13 ^ 3) // 结果 14
	// 右移n位就是除以2的n次方。
	// “a>>b”是把a的各二进位全部右移b位。
  fmt.Println(3 >> 10) // 3的二进制 11 变成 : 110000000000 结果: 3072 也就是 2的11次方 2的10次方
	// 左移n位就是乘以2的n次方。
	// “a<<b”是把a的各二进位全部左移b位,高位丢弃,低位补0。
	fmt.Println(3 << 1) //结果 1 高位就丢弃了
}

这是怎么算出来的呢? 上图:

未命名文件

赋值运算符

运算符 描述
= 简单的赋值运算符,将一个表达式的值赋给一个左值
+= 相加后再赋值
-= 相减后再赋值
*= 相乘后再赋值
/= 相除后再赋值
%= 求余后再赋值
<<= 左移后赋值
>>= 右移后赋值
&= 按位与后赋值
|= 按位或后赋值
^= 按位异或后赋值

这个就不多说了.

练习题

有一堆数字,如果除了一个数字以外,其他数字都出现了两次,那么如何找到出现一次的数字?

代码:

package main
import "fmt"
func main()  {
	// 发现了一个规律 任何数和 0做异运算都等于那个数的本事
	// 任何数和 自身做运算都等于0
	// 异运算 满足交换率和结合率  出现了一个规律 如果说你的数组重复多个值 只有一个值不重复 隔着一个出现那个 不重复的值
	// 即等于 : a ^ b ^ a=b ^ a ^ a=b ^ (a ^ a) = b ^ 0=ba⊕b⊕a=b⊕a⊕a=b⊕(a⊕a)=b⊕0=b。

	var a = []int{1,1,2,2,3,4,4,5,5}
	var res = 0
	for i:=0;i<len(a);i++{
		res = res ^ a[i]
		// 0 1 = 1
		// 1 1 = 0
		// 0 2 = 2
		// 2 2 = 0
		// 0 3 = 3
		// 3 4 = 7
		// 7 4 = 3
		// 3 5 = 6
		// 6 5 = 3
	}
	fmt.Println(res)


}
posted @ 2021-01-21 18:14  PythonAV  阅读(144)  评论(0编辑  收藏  举报