2014蓝桥杯真题 Java B组——扑克序列

7 扑克序列
    A A 2 2 3 3 4 4, 一共4对扑克牌。请你把它们排成一行。
    要求:两个A中间有1张牌,两个2之间有2张牌,两个3之间有3张牌,两个4之间有4张牌。

    请填写出所有符合要求的排列中,字典序最小的那个。

例如:22AA3344 比 A2A23344 字典序小。当然,它们都不是满足要求的答案。


请通过浏览器提交答案。“A”一定不要用小写字母a,也不要用“1”代替。字符间一定不要留空格。

找到一个很巧妙地思路:

存在一个长度为8的数组,那么其上8个数字要排在该数组中。设第一个A的下标是ma ,那么第二个A的下标就是ma+2 ; 同理第一个2的下标为m2,第二个2的下标就为m2+3;3和4就说了,道理一样。那么我就让这些下标组成一个字符数组,经过从大到小的排序字符,只要满足下标各不相等就可以了。

代码如下:

package lanqiaobei;

import java.util.Arrays;

public class Ti2014_puke {
	 public static void main(String[] args) {  
	        showMethod();  
	    }  
	      
	    static void showMethod(){  
	        for(int ma = 1 ; ma <= 6 ; ma++){  
	            for(int m2 = 1 ; m2 <= 5 ; m2++){  
	                for(int m3 = 1 ; m3 <= 4 ; m3++){  
	                    for(int m4 = 1 ; m4 <= 3 ; m4++){  
	                        String str = "" +ma+m2+m3+m4+(ma+2)+(m2+3)+(m3+4)+(m4+5) ; 
	                        /*
	                         * 下面这段只是为了排除有相同字符的情况
	                         */
	                        String[] getStr = str.split("");
	                        boolean flag = true ;  
	                        Arrays.sort(getStr);  
	                        for (int i = 0; i < getStr.length-1; i++) {  
	                            if(getStr[i].equals(getStr[i+1])){  
	                                flag = false ;  
	                                break ;  
	                            }  
	                        }  
	                        /*
	                         * 上面一段为了排除有字符相等的情况
	                         */
	                        if(flag){  
	                            System.out.println(str);  
	                        }  
	                    }  
	                }  
	            }  
	        }  
	    }
}

答案:

25314876

51237468

按照顺序分回去

按照前四个是ma、m2、m3、m4的顺序分回去:比如
25314876
ma=2,说明A在第二个位置
m2=5,说明2在第五个位置
m3=3,说明3在第三个位置
m4=1,说明4在第一个位置
综上,4A3A2432


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值