牛牛有一个长度为n的整数序列s,羊羊要在牛牛的序列中选择不同的两个位置,然后交换这两个位置上的元素。现在需要求出羊羊交换后可以得到的不同的序列个数。(注意被交换的两元素值可能相同)。
如序列{1, 47},输出1.羊羊必须交换仅有的两个元素,得到序列{47, 1}。羊羊必须交换,不能保留原有的序列。
{1, 2, 1},输出3.羊羊通过交换可以得到{2, 1, 1},{1, 1, 2},{1, 2, 1}这三个序列。
输入包括两行,第一行为一个整数n(2 ≤ n ≤ 50),即序列的长度。 第二行n个整数,表示序列的每个元素a_i(1 ≤ a_i ≤ 50),以空格分割。
输出一个整数,表示羊羊可以得到的不同的序列个数
3 1 2 1
3
import java.util.Scanner; import java.util.ArrayList; public class Main { public static void main(String[] args) { Scanner sca = new Scanner(System.in); ArrayList Int = new ArrayList(); int n = sca.nextInt(); //coun1记录共多少次交换 coun记录重复次数 o排除第一次与本身相同 int coun=0 ,coun1=0; int o=0; for (int i = 0; i < n; i++) { Int.add(sca.nextInt()); } for(int i=0;i<n;i++) { for(int j=i+1;j<n;j++) { coun1++; if(Int.get(i)==Int.get(j)) { if(o!=0) coun++; o=1; } } } System.out.println(coun1-coun); } }