算法学习01 逆序数和全排列

今天寒假第一天开始认认真真的学习Java算法,主要学习了两个题。

1.逆序数

就是找这个数的后面,有几个数比它小

import java.util.Iterator;
import java.util.Scanner;

public class Inversion_num {

	 public static void main(String args[]){  
		 
		 Scanner input =new Scanner(System.in);
	        boolean operation=true;
	        while(operation) {
	        	String string=input.nextLine();
	        	System.out.println(inversionNum(string));
	        	operation=false;
	        }


	    }
	      
	       
	 public static int  inversionNum(String string){
		 int count=0;
		 String a[]=string.split(" ");
		 int b[]=new int[a.length];
		 for(int i=0;i<a.length;i++) {
			 b[i]=Integer.parseInt(a[i]);
		 }//将输入的字符串以空格分开,存到新的整形数组b中
		 for(int j = 0;j<b.length;j++) {
			 for (int i = j+1; i < b.length; i++) {
				
			
			 if(b[j]>b[i]) {
				 count++;
			 }
			 }
		 }
		 
		return count;
		 
	 }
	}  

input:

4 3 6 5 1 2

output:

10




2.全排列

运用递归的方式来处理全排列,最后把结果存到TreeSet中,剔除重复值。

import java.util.Scanner;
import java.util.TreeSet;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class W01 {
	long count=0;
	
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		//Scanner scanner=new Scanner(System.in);
		//int n=scanner.nextInt();
	  List<Integer> s=new ArrayList<Integer>();  
         List<Integer> rs=new ArrayList<Integer>();  
		s.add(3);
		s.add(2);
		s.add(2);
		s.add(1);
		s.add(4);
		s.add(5);
		fullpermutation(s,rs);
		
		 Iterator<String> iterator=ts.iterator();  
	        while (iterator.hasNext())   
	           System.out.println(iterator.next());  
	        
	        System.out.println("总数是:"+ts.size());  
	}
		static TreeSet<String> ts=new TreeSet<String>();
	private static void fullpermutation(List<Integer> s, List<Integer> rs) {
		// TODO Auto-generated method stub

		if(s.size()==1) {
			
			rs.add(s.get(0));
			//System.out.println(rs.toString());
			ts.add(rs.toString());
			rs.remove(rs.size()-1);
		
		
		}else {
			for(int i=0;i<s.size();i++) {
				
				rs.add(s.get(i));
			
				List<Integer> tmp=new ArrayList<Integer>();
				for (Integer a : s) {
					tmp.add(a);
				}		
			tmp.remove(i);
			fullpermutation(tmp, rs);
			rs.remove(rs.size()-1);

			}
		}
	}

}

output:

…………

…………
[5, 4, 2, 2, 1, 3]
[5, 4, 2, 2, 3, 1]
[5, 4, 2, 3, 1, 2]
[5, 4, 2, 3, 2, 1]
[5, 4, 3, 1, 2, 2]
[5, 4, 3, 2, 1, 2]
[5, 4, 3, 2, 2, 1]
总数是:360



感觉在算法方面还是比较小白,继续加油努力!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值