1.%:取余运算(模除)
结果的符号与被模数的符号相同
被模数 % 模数 = 余数
开发中,经常使用%来判断能否被除尽的情况
2.自增、自减运算符
(前)++:(++a)先自增1、后运算表达式
(后)++:(a++)先运算表达式赋值、后自增1
(前)--:(--a)先自减1、后运算表达式
(后)--:(a--)先运算表达式赋值、后自减1
自增1不会改变本身变量的数据类型
3.赋值运算符
=、+=、-=、*=、/=
可以连续赋值
例如:
int j,i;
j = i = 10;
说明:在 s1 = s1 + 2;中s1是short类型,2默认是int类型,java中不支持数据类型自动向下转型,所以编译错误。
“+=”等,赋值运算符不会改变变量的数据类型
4.逻辑运算符
&与&&
5.移位运算符
【面试题】你能否写出最高效的2 * 8的实现方式?
答:2 << 3 或 8 << 1
【特别说明】
1.位运算符 *** 作的都是整形的数据
2. << :在一定范围内,每向左移1位,相当于 * 2
>>:在一定范围内,每向右移1位,相当于 / 2
6.三元运算符
三元运算符可以嵌套
注意:
二、流程控制1.凡是可以使用switch-case的结构,都可以转换为if-else,反之,不成立
2.当分支结构,两种分支都可以使用时,(switch表达式取值不多),优先使用switch。原因:switch执行效率稍高
- 分支结构
- if-else
if(条件表达式){
执行表达式1;
}else{
执行表达式2;
}
else 的配对原则:else总是与最近的if配对(就近原则)
if-else可以进行嵌套
课后练习:如何获取一个随机数:10~99
Math.random();//获取随机数[0.0,1.0)
[0.0,1.0)-->[0.0,90.0)-->[10.0,100)-->[10,100)
int value = (int)(Math.random()*90+10)
公式:[a,b] : (int)(Math.random() * (b - a +1)+a)
2.switch-case
说明:
①根据Switch表达式中的值,一次匹配各个case中的常量,一旦匹配成功,则进入相应的case结构中,调用其执行语句。当调用完执行语句之后,仍然继续向下执行其他case中的执行语句,直到遇到bresk关键字或此Switch-case结构末尾为止
②break关键字,一旦执行到此关键字就跳出,break可以用在switch-case和if语句中
③switch结构中的表达式,只能是如下的6中数据类型之一:byte、short、char、int、枚举类型(JDK5.0)、String类型(JDK7.0)
④如果switch-case结构中多个case执行语句相同,则可以考虑进行合并
- 循环结构
1.循环结构的4个要素
①初始化条件
②循环条件 -->boolean类型
③循环体
④迭代条件(自增)
2.三种循环结构
①for循环
for(①;②;④){
③
}
执行过程:①-②-③-④-②-③-④.....
②while循环
①
while(②){
③;
④;
}
执行过程:①-②-③-④-②-③-④.....
for和while循环总结:
1.开发中,基本上都会在for、while中进行选择,实现循环结构
2.for循环和while循环是可以相互转换的!
区别:for和while的初始化条件的作用范围不同
3.写程序避免死循环
③do-while循环
①
do{
③;
④;
}while(②)
执行过程:①-③-④-②-③-④-②.....
while至少执行一次循环
特殊情况:
1.“无限循环”(不在循环条件部分限制次数的结构):for(;;)或while(true)
2.结束循环有几种方式
方式一:循环条件部分,返回false
方式二:在循环体中,执行break
嵌套循环
内层循环遍历一遍,相当于外层循体环执行一次
技巧:外层循环控制行数,内层循环控制列数
求100以内素数的优化
【练习题】
练习一:打印三角形
练习二:九九乘法表
练习三:100以内的质数
如何理解流程控制的练习:
流程控制结构的使用 + 算法逻辑
- 关键字:break;continue
补充:
结束指定标识的一层循环
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)