全排列(编程之美)

字符串全排列

public class Q {

	/**
	 * @param args
	 */
	static int count=0;
	public static void main(Strin<pre name="code" class="html">public class Q {

	/**
	 * @param args
	 */
	static int count = 0;

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		StringBuffer a = new StringBuffer("abdbefb");
		q(a, 0, a.length() - 1);
		System.out.println(count);
	}

	private static void q(StringBuffer a, int i, int j) {
		// TODO Auto-generated method stub
		if (i >= j) {

			System.out.println(a);
			// System.out.println();
			count++;
		} else {
			for (int k = i;k<= j; k++) {
				//if (a.charAt(k) != a.charAt(k + 1) ) {
				if(isSwap(a,i,k))
				{
					swap(a, i, k);
					q(a, i + 1, j);
					swap(a, i, k);
				}

			}
		}

	}

	static boolean isSwap(StringBuffer str,int begin,int end)  
	{  
	   for(int i=begin;i<end;i++)  
	    {  
	        if(str.charAt(begin)==str.charAt(end))  
	            return false;  
	    }  
	    return true;  
	  
	}  
	private static void swap(StringBuffer a, int i, int k) {
		// TODO Auto-generated method stub
		char temp = a.charAt(i);
		a.setCharAt(i, a.charAt(k));
		a.setCharAt(k, temp);

	}

}

 

字符串去重

public class Q {

	/**
	 * @param args
	 */
	static int count = 0;

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		StringBuffer a = new StringBuffer("abdbefb");
		q(a, 0, a.length() - 1);
		System.out.println(count);
	}

	private static void q(StringBuffer a, int i, int j) {
		// TODO Auto-generated method stub
		if (i >= j) {

			System.out.println(a);
			// System.out.println();
			count++;
		} else {
			for (int k = i;k<= j; k++) {
				//if (a.charAt(k) != a.charAt(k + 1) ) {
				if(isSwap(a,i,k))
				{
					swap(a, i, k);
					q(a, i + 1, j);
					swap(a, i, k);
				}

			}
		}

	}

	static boolean isSwap(StringBuffer str,int begin,int end)  
	{  
	   for(int i=begin;i<end;i++)  
	    {  
	        if(str.charAt(begin)==str.charAt(end))  
	            return false;  
	    }  
	    return true;  
	  
	}  
	private static void swap(StringBuffer a, int i, int k) {
		// TODO Auto-generated method stub
		char temp = a.charAt(i);
		a.setCharAt(i, a.charAt(k));
		a.setCharAt(k, temp);

	}

}



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值