題目描述
九陣列分數
1,2,3…9 這九個數字組成一個分數,其值恰好為1/3,如何組法?
下面的程式實作了該功能,請填寫劃線部分缺失的代碼,
public class A
{
public static void test(int[] x)
{
int a = x[0]*1000 + x[1]*100 + x[2]*10 + x[3];
int b = x[4]*10000 + x[5]*1000 + x[6]*100 + x[7]*10 + x[8];
if(a*3==b) System.out.println(a + " " + b);
}
public static void f(int[] x, int k)
{
if(k>=x.length){
test(x);
return;
}
for(int i=k; i<x.length; i++){
{int t=x[k]; x[k]=x[i]; x[i]=t;}
f(x,k+1);
_______________________________________ // 填空
}
}
public static void main(String[] args)
{
int[] x = {1,2,3,4,5,6,7,8,9};
f(x,0);
}
}
注意,只能填寫缺少的部分,不要重復抄寫已有代碼,不要填寫任何多余的文字,
解題思路
本題想通過遞回完成全排列,而遞回生成全排列的思路就是將陣列的元素進行交換,但是交換完必須再交換回去,
參考代碼
{t=x[k]; x[k]=x[i]; x[i]=t;}
注意:花括號不可缺,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/258940.html
標籤:java
上一篇:自學Java網路爬蟲-Day1
下一篇:函式與編程
