Uva489_Hangman Judge心得感悟

其实碰到看题目有就一点思路的题,我就知道题目其实不是很难,也不会转很多弯子,所以信心满满的写了个个大概思路去做了就。
第一阶段,写出的代码能差不多符合例样的数值,本想着对着udebug的数值就可以,结果一对发现太多答案不对了,这下我懵逼了。
**

**问题:**利用split函数时,"."作为特殊字符,需要利用//来转义,学到了学到了。

**
第二阶段,试着看了一下输入输出格式(其实第一阶段的时候 已经大略的看过了,因为紫书上也有),发现自己没有注意到“”猜一个已经猜错的字母算错“”这段话。然后又做了相应的修改。然后再去debug 发现和第一个的结果还是不对,于是心存侥幸的去试了其他几组的数据,发现有对有错。然后一个个对着改。
第三阶段,我已经陷入了无法理解题意到底是要干嘛,其实英文的意思我都看得懂,但是还是不确定。然后我看一组样例的时候,不理解为什么是这个结果,然后我开始自己脑补,最后得出了一个错误的结论。当用户猜数据的时候,不是拿用户输入的一个去比较,是否出现了这个数字,而是直接找出计算机的所有数据,之后在考虑猜错的数据(这个想法非常混乱),以至于后期我改了无数遍的其他地方,但是答案总是有问题。
第四阶段,我开始搜其他人的题解,发现大家的说法看的我更混乱了。我开始去研究题目的要求和本意,再去详读了第一组数据,然后我发现了我豁然开朗。。。
其实根本没有说猜一个已经猜过的字母是错误的。

真正的要求只有三点:
第一点:按序读用户输入的字母,如果不是计算机给的字母中的,就算作错。后面你再猜这个字母也不会算你错,一个字母只错一次。
第二:计算机给的单词,只按字母数来判断,不看字母出现的次数,即使计算机给了100个a也只算一个a。
第三:在七次内猜到了所有单词就跳出猜测,从而去判断猜到了所有单词,就是win,不管你后期还在猜没有。

总结:
这个其实并不难的题目,花了我一个晚上都还是wa,但是呢。第二天我冷静的来看题来看解释和样例,在自己理解了输入输出之后,很快就做完了。
我突然意识到读题的重要性,紫书上并不完全正确,在我搜寻别人的题解时,有人给出了紫书的代码,但是下面有人评论,说这个WA了,我才意识到,紫书上的问题解释可能并不完全正确,要想看正确得,还是的去看uva上面详细的内容。
但是其实也很好笑,因为自己太懒惰的原因,结果花了更多的时间,真是不应该啊。
吃一堑长一智吧。
昨天的IP地址那题,也同理可证,在没有完全理解题目要求和意思的情况就去做,我就像个裁缝,缝缝补补的修改着程序。很多时候太浪费时间,而且很耗费精力!
希望自己能吸取教训,


```java
public class Uva489 {

	public static void main(String[] args) {
	Scanner in = new Scanner(System.in);
	 String n1 = in.nextLine();
	 int n = Integer.parseInt(n1);
	 
	 while(n!=-1)
	 {
		 int[] alp = new int[27];
		 int[] alpp = new int[27];
		 String a1  = in.nextLine();
		 a1 = a1.toLowerCase();
		 String a2  = in.nextLine();
		 a2 = a2.toLowerCase();
		 
		 for(int i =0;i<a1.length();i++)
		 {
			 alp[a1.charAt(i)-'a'+1]++;
			 if(alp[a1.charAt(i)-'a'+1]==1)  //说明重复了
				 alp[0]++;
		 }
		 
		 
		 for(int i =0;i<a2.length();i++)
		 {
			 alpp[a2.charAt(i)-'a'+1]++;
				 alpp[0]++;
		 }
		 
		 int wrong =0;
		 int i =0;
		 boolean fa = true;
		 
		for(;i<a2.length();i++)
		 {    
			 
			 if((alp[a2.charAt(i)-'a'+1])>0) //表示出现过 计算机的元素 玩家想到过
			 {  
				alp[0]--;//找到一个了
			 alp[a2.charAt(i)-'a'+1] = -1;  //被找到过 下一次 相同的字母不作数 
			 }
			 else if(alp[a2.charAt(i)-'a'+1] ==0)  //找错元素
  		     {
				 wrong++;
				 alp[a2.charAt(i)-'a'+1] =-1;
			 }
			 if(alp[0]==0)
			  {
				 fa = false;
				 break;
			  }
			 if(wrong>=7)
				 break;
		 }
		 
		 System.out.println("Round "+n);
		 
		 if(alp[0]==0)
			 System.out.println("You win.");	 
		else if(wrong>=7)
			 System.out.println("You lose.");
		else 
			System.out.println("You chickened out.");
	  
		 n1 = in.nextLine();
		 n =  Integer.parseInt(n1);
	 } 	 
	 }
	 
}



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值