您的位置:首页 > 编程语言 > Java开发

Java 基础逻辑判断

2011-07-19 23:11 232 查看
package org.zhanghua.javase.grammar;

import java.util.Random;

/**
* 逻辑判断 if/else、for、while、do/while、switch
*
* @author ZhangHua
*
*/
public class Logical {
/**
* if if-else if-else if if-else if else
*
* 注意:只有一句话时,可以省略{}
*/
public void testIF() {
int i = 20;
if (i < 20) {
System.out.println("小于20!");
}
else if (i < 40) {
System.out.println("小于40!");
}
else if (i < 60) {
System.out.println("小于60!");
}
else {
System.out.println(">=60!");
}
}

/**
* for fore while do-while
*/
public void testCycle() {
for (int i = 0; i < 10; i++) {
System.out.println("i=" + i);
}
System.out.println("+++++++++++++++++++++++++++");
int[] is = new int[5];
// 初始化is数组
for (int i = 0; i < is.length; i++) {
is[i] = i;
}
for (int i : is) {
System.out.println("i=" + i);
}
System.out.println("+++++++++++++++++++++++++++");
int i = 1;
while (i > 0) {
System.out.println("i=" + i);
i++;
if (i == 10) {
break;
}
}
System.out.println("+++++++++++++++++++++++++++");
int x = 1;
do {
System.out.println("x=" + x);
x++;
if (x == 10) {
break;
}
} while (x > 0);
}

/**
* switch
*
* 注意:只有用于int,short,char,boolean
*/
public void testSwitch() {
Random random = new Random();
int i = random.nextInt(10);
switch (i) {
case 1:
System.out.println("i=1");
break;
case 2:
System.out.println("i=2");
break;
case 3:
System.out.println("i=3");
break;
case 4:
System.out.println("i=4");
break;
case 5:
System.out.println("i=5");
break;
default:
System.out.println("i=" + i);
break;
}
}

/**
* 递归 顾名思义:就是对自己调用
*
* @param args
*/
public int testRecursion1(int i) {
if (i == 1) {
return 1;
}
else {
// i * testRecursion(i - 1)
// 对自己调用,假如i=5-->test(4)-->test(3)-->test(2)-->test(1),然后再返回
return i * testRecursion1(i - 1); // 5*testRecursion(4)=5*4*testRecursion(3)=5*4*3*testRecursion(2)=5*4*3*2*1=120
}
}

/**
* 1、1、2、3、5、8、13 ... Fibonacci数列
*
* @return 结果
*/
public int testRecursion2(int i) {
if (i == 1 || i == 2) {
return 1;
}
else {
// 递归调用,第三个数等于第一个数加上第二个数的和。Fn=Fn-1+Fn-2
return testRecursion2(i - 1) + testRecursion2(i - 2);
/**
* 分析过程: 例如i=5 main-->i=5
* test(5-1)--test(4)--test(3)--test(2)--test(
* 1)--test(1)--test(2)--test
* (1)--test(3)--test(2)--test(1)--test(3)--test(2)--test(1)
*/
}
}

/**
* 使用循环模拟testRecursion2
*
* @param args
*/
public long testRecursion3(int index) {
if (index < 0) {
System.out.println("请输入正确的索引");
return -1; // 或 System.exit(0);
}
if (index == 1 || index == 2) {
return 1;
}
// 1,1,2,3...三个数来回倒置
long f1 = 1L;
long f2 = 1L;
long f = 0;
// f1,f2不用循环,所以少2次循环
for (int i = 0; i < index - 2; i++) {
f = f1 + f2;
f1 = f2;
f2 = f;
}
return f;
}

public static void main(String[] args) {
Logical logical = new Logical();
System.out.println("testIF:");
logical.testIF();
System.out.println("testCycle:");
logical.testCycle();
System.out.println("testSwitch:");
logical.testSwitch();
System.out.println("testRecursion1:");
int resoult = logical.testRecursion1(5);
System.out.println(resoult);
System.out.println("testRecursion2:");
resoult = logical.testRecursion2(5);
System.out.println(resoult);
System.out.println("testRecursion3:");
long number = logical.testRecursion3(40);
System.out.println(number);
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: