python算数、逻辑运算,位运算
算术运算符
对变量和数组进行算术运算。
算术运算符:+,-,*,/,%
+:将连个或者多个数值相加
-:将两个数值相减
*:将两个数值相乘
/:将两个数值相除
%:取相除的余数
赋值运算符
将右边的值(计算结果)赋值给左边的变量
赋值运算符:=,+=,-=,*=,/=,%=,.=
=:赋值,将右边的值赋值给左边的变量
+=:将左边的变量的值加上右边的结果之后,再将值赋值给左边的变量
-=,*=,/=,%=,.=都是一样的效果
注意!!!“.”十分特殊,表示一种字符串连接运算
抑制错误,不让错误出现
错误抑制符:@
三元运算符
参与运算的表达式有三个
语法:表达式1 ? 表达式2 : 表达式3
如果表达式1为真,那么计算表达式2,否则计算表达式3
<?php
$wenheichouwa = "ishere";
$res = ($wenheichouwa=="ishere")?"喜欢小烤肠和小松鼠":"喜欢昌仔";
echo $res."<br/>";
$duwa = &$wenheichouwa;
$duwa = "nothere";
echo $res."<br/>";
echo $wenheichouwa."<br/>";
echo $duwa."<br/>";
$res = ($wenheichouwa=="ishere")?"喜欢小烤肠和小松鼠":"喜欢昌仔";
echo $res."<br/>";
?>
自操作运算符
自己操作自己的运算符
自操作运算符:++,--
++:分为前置++和后置++,$a = $a + 1
前置++:++$a,
后置++:$a++
通常,在循环中,使用自运算比较,用户控制循环变量。
字符串运算符
连接字符串
字符串运算符:.和.=
$a = ‘hello ’;
$b = ‘world’;
.:表示两个字符串连接,不会改变原来的变量本身
$c = $a . $b;
.=:将两个字符串连接起来后再赋值给左边的变量
$a .= $b <===========> $a = $a . $b;
位运算符
针对系统硬盘上存储的位进行操作(实际操作是以字节为单位),位运算在计算过程中,每个位的操作返回的结果都是1或者0
位运算符:&,|,~,^,>>,<<
&:按位与,表示两个位都为1时,则返回1,否则返回0
|:按位或,表示两个有一个为1的时候,返回1,否则返回0
~:按位非,如果本身为0,则返回1,如果本身为1,则返回0
^:按位异或,如果两位不相同时,则返回1,如果两位相同则返回0
>>:按位右移,将整个字节向右移一位,左边空出来的使用0补充
<<:按位左移,将整个字节向左移一位,右边空出来的使用0补充
右移运算乃是原来的结果右移几位就除以几个2,然后向下取整,左移运算是原来的结果左移几位就乘以几个2;
<?php
$mynum=5;
echo "mynum左移5位的最终结果是".($mynum<<6)."<br/>";
$hisnum=6;
echo "hisnum右移2位的结果是".($hisnum>>2)."<br/>";
?>
原码,反码,补码
原码----一个数的二进制形式
反码----一个数二进制按位取反
补码----一个数二进制按位取反并加1,一个正数的原码,反码,补码都相同
存储的实际情况----正数以原码的形式存储,负数以补码的形式存储。
以整数1为例,我们知道php的整型数占4个字节,每个字节占8位,正数的原码,反码,补码又都相同,正数的最高位是0,所以对于1有 #原码
#反码
#补码
负数反码。补码的错误操作形式 而对于-1来说,按照既定原则,最高位应该为1,所以他的原码形式为
#原码
反码就是各位取反
#反码
补码就是反码各位再加1
01111111 11111111 11111111 11111110
+
00000000 00000000 00000000 00000001
=
01111111 11111111 11111111 11111111
但是问题显然出现了,最终结果 01111111 11111111 11111111 11111111 明显是个正数! 所以对于负数来说,他的反码形式是 最高位不动,其余的位取反
正确姿势,负数的反码最高位不变,其他位取反 -1的反码 #反码11111111 补码 = 反码+ + =
补码为
php提供了几常见进制之间转换的函数
二进制转为其他进制
binoct();//转为八进制
bindec();//转为十进制
binhex();//转为十六进制
八进制转为其他进制
octbin();//转为二进制
octdec();//转为十进制
octhex();//转为十六进制
十进制转为其他进制
decbin();//转为二进制
decoct();//转为八进制
dechex();转为十六进制
十六进制转为其他进制
hexbin();转为二进制
hexoct();//转为八进制
hexdec();//转为十六进制
python算数、逻辑运算,位运算的更多相关文章
- Linux - Shell - 算数表达式 - 位运算
概述 shell 中基于 $(()) 的 位运算 背景 复习 shell 脚本 凑数吧 准备 环境 os centos7 1. 位运算 代码 #!/bin/bash # 位运算 arg1=2 arg2 ...
- python的按位运算
#coding=utf-8#"&"按位与运算,是指一个数字转化为二进制,然后这些二进制的数按位来进行与运算a=7&18print a'''首先将7转化为二进制,得到 ...
- python中的位运算
目录 1.判断奇偶数 2.交换两个数 3.找出没有重复的数 4.3的n次方 5. 找出不大于N的最大的2的幂指数 1.判断奇偶数 如果把n以二进制形式展示的话,我们只需要判断最后一个二进制位是1还是0 ...
- python数据类型和数据运算
数字 整型 包括正整数和负整数,和数学的表示方法一样.如:1.100.8008.-12等. 浮点型 浮点数字也称为小数,如果按照科学计数法表示时,小数点的位置是可变的.如:1.23x109==12.3 ...
- jave 逻辑运算 vs 位运算 + Python 逻辑运算 vs 位运算
JAVA中&&和&.||和|(短路与和逻辑与.短路或和逻辑或)的区别 博客分类: 面试题目 Java.netBlog 转自 :http://blog.csdn.net/web ...
- golang中算数运算、位运算、逻辑运算、赋值运算常用方法
package main import "fmt" var a = 21.0 var b = 5.0 //var c float64 func main() { Arithmeti ...
- C语言中的位运算和逻辑运算
这篇文章来自:http://blog.csdn.net/qp120291570/article/details/8708286 位运算 C语言中的位运算包括与(&),或(|),亦或(^),非( ...
- 剑指offer用位运算实现两个数相加,及python相关的位操作
题目:写一个函数,求两个整数之和,要求在函数体内不得使用+.-.*./四则运算符号. 代码: # -*- coding:utf-8 -*-class Solution: def Add(self ...
- 利用位运算进行a+b的计算(Java&&Python)
题目链接 需要用到的位运算操作:异或(^).与(&).右移(<<) 异或运算:又称不进位加法,a^b得到的结果为a与b相加,但是需要进位的地方不进位得到的结果 与运算:找出来a和b ...
随机推荐
- 面试题 :10亿url去重只给4G内存
我能想到的有以下几种: 用语言判断去重,ex表格去重,数据库去重,文件名字去重, 有人说:10亿url ex表放不下!! 可以用树和折半的思想将10亿url,变成单元最小化的树,然后用ex表去重 ex ...
- Macaca环境搭建(三)----uirecorder Android录制
一.安装Macaca-Android 命令窗口输入:npm i macaca-android -g 二.安装android-SDK 1.下载并安装ADT-bundle,官网下载地址我就不提供了,因为下 ...
- JAVA验证
1.一个JAVA类只能有一个主类. 2.main()方法返回值改为int,不能运行 3.变量作用域有限 实例: 4.数值类型在内存中直接存储其本身的值,对于不同的数值类型,内存中会分配相应的大小去存储 ...
- 云数据库RDS SQL Server 版
云数据库RDS SQL Server版是一种可弹性伸缩的在线数据库服务,并具备自动监控.备份.容灾恢复等方面的全套解决方案,彻底解决数据库运维的烦恼 请观看视频简介 SQL Server是发行最早的商 ...
- Oracle集群检测命令
select inst_id, count(inst_id) from gv$session group by inst_id order by inst_id; srvctl stop databa ...
- # 匈牙利算法(二分图最大匹配)- hdu 过山车
匈牙利算法(二分图最大匹配)- hdu 过山车 Hdu 2063 二分图:图中的点可以分成两组U,V,所有边都是连接U,V中的顶点.等价定义是:含奇数条边的图. 匹配:一个匹配是一个边的集合,其中任意 ...
- Django基础之路由(urls)层
目录 Django基础之路由(urls)层 无名分组与有名分组 无名分组 有名分组 反向解析 前段解析 后端解析 无名分组反向解析 前段解析 后端解析 有名分组的反向解析 前段解析 后端解析 路由分发 ...
- 移除django的旧版本
移除django的旧版本 下面这一段代码打进去绝对能看到你想要的,根据这个路径去找版本文件夹,他的名字应该是django.2xx.xxx很长一段,请你删了它! import django import ...
- nohup重定向到其它的日志文件
如果使用nohup命令提交作业,那么在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件: nohup command > myout.file 2 ...
- The minimal unique substring CodeForces - 1159D (构造)
核心观察是形如01,001,0001,...的串循环时, $n$每增长1, $k$就增长1. #include <iostream> #include <sstream> #i ...