A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© wenhb 中级黑马   /  2018-2-1 15:59  /  539 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

方法1)方法:
1)封装一段特定的业务逻辑功能

2)方法尽可能的独立,一个方法只干一件事

3)方法可以被反复调用多次

4)减少代码的重复,有利于代码的维护,有利于团队的协作
2)方法的定义:

修饰词 返回值类型 方法名(参数列表){                方法体}  
(1)当方法需要结果时设计返回值的类型(2) 当不需要结果时候,设计反回自的类型为void (3)返回结果通过通过return关键字 
3)方法的调用
(1)无返回值: 方法名(有参传参);
(2)有返回值: 数据类型 变量 = 方法名(有参传参);
4)return的用法:(1)return 值; //1.1)结束方法的执行 1.2)返回结果给调用方   (2)return;    //2.1)结束方法的执行(只能用在无返回值的方法中)
[Java] 纯文本查看 复制代码
//**方法的演示
//1.有参有返回值
	public static double plus(double num1,double num2){
		double num = num1+num2;
		return num; //返回的是num中的那个数		
		//return num1+num2; //返回num1与num2的和
	}
	
//2.无参有返回值
	public static int getNum(){
		//return; //编译错误,return后必须跟一个值
		//return 8.88; //编译错误,return的值必须与返回值类型匹配
		return 88; //1)结束方法的执行 2)返回一个值给调用方
	}
	
//3.有参无返回值
	public static void sayHi(String name){
		System.out.println("大家好,我叫"+name);
		 if(boolean){
		 return; //1)结束方法的执行
		}
	}
	
//4.无参无返回值
	public static void say(){
		System.out.println("大家好,我叫WKJ");
	}	
}

[Java] 纯文本查看 复制代码
//**猜字符小游戏
import java.util.Scanner;
//猜字符小游戏
public class Guessing {
	//主方法
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		char[] chs = generate(); //获取随机字符数组
		System.out.println(chs);
		int count = 0; //猜错的次数
		while(true){ //自造死循环
			System.out.println("猜吧!");
			String str = scan.next().toUpperCase(); //获取用户输入的字符串,并转换为大写字母
			if(str.equals("EXIT")){
				System.out.println("下次再来吧!");
				break;
			}
			char[] input = str.toCharArray(); //将字符串转换为字符数组
			int[] result = check(chs,input); //对比随机字符数组与用户输入的字符数组
			if(result[0]==chs.length){ //猜对了
				int score = 100*chs.length-10*count; //1个字符100分,猜错一次扣10分
				System.out.println("恭喜你,猜对了!,得分为:"+score);
				break;
			}else{ //猜错了
				count++; //猜错次数增1
				System.out.println("字符对个数为:"+result[1]+",位置对个数为:"+result[0]);
			}
		}
	}
	
	//生成随机字符数组
	public static char[] generate(){
		char[] chs = new char[5]; //随机字符数组
		char[] letters = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',
				'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V',
				'W', 'X', 'Y', 'Z' }; //随机字符范围数组
		boolean[] flags = new boolean[letters.length]; //开关数组(与letters相对应)
		for(int i=0;i<chs.length;i++){ //遍历随机字符数组
			int index;
			do{
				index = (int)(Math.random()*letters.length); //随机下标(0到25)
			}while(flags[index]==true); //当下标index对应的开关为true时,表示已存过,则重新生成下标index
			                            //当下标index对应的开关为false时,表示未存过,则字符可存,循环结束
			chs[i] = letters[index]; //基于下标index到letters中获取字符,并赋值给chs中的每一个元素
			flags[index] = true; //将下标index对应的开关修改为true,表示已存过
		}
		return chs;
	}
	
	//对比:随机字符数组与用户输入的字符数组
	public static int[] check(char[] chs,char[] input){
		int[] result = new int[2]; //对比的结果,假设result[1]为字符对个数,result[0]为位置对个数
		for(int i=0;i<chs.length;i++){ //遍历随机字符数组
			for(int j=0;j<input.length;j++){ //遍历用户输入的字符数组
				if(chs[i]==input[j]){ //字符对
					result[1]++; //字符对个数增1
					if(i==j){ //位置对
						result[0]++; //位置对个数增1
					}
					break; //剩余input元素不再参与比较了
				}
			}
		}
		return result;
	}
}


0 个回复

您需要登录后才可以回帖 登录 | 加入黑马