1. 程式人生 > >藍橋杯2013試題——顛倒的價牌

藍橋杯2013試題——顛倒的價牌

標題: 顛倒的價牌


小李的店裡專賣其它店中下架的樣品電視機,可稱為:樣品電視專賣店。

其標價都是4位數字(即千元不等)。

小李為了標價清晰、方便,使用了預製的類似數碼管的標價籤,只要用顏色筆塗數字就可以了(參見p1.jpg)。

這裡寫圖片描述

這種價牌有個特點,對一些數字,倒過來看也是合理的數字。如:1 2 5 6 8 9 0 都可以。這樣一來,如果牌子掛倒了,有可能完全變成了另一個價格,比如:1958 倒著掛就是:8561,差了幾千元啊!! 

當然,多數情況不能倒讀,比如,1110 就不能倒過來,因為0不能作為開始數字。

有一天,悲劇終於發生了。某個店員不小心把店裡的某兩個價格牌給掛倒了。並且這兩個價格牌的電視機都賣出去了!

慶幸的是價格出入不大,其中一個價牌賠了2百多,另一個價牌卻賺了8百多,綜合起來,反而多賺了558元。

請根據這些資訊計算:賠錢的那個價牌正確的價格應該是多少?

答案是一個4位的整數,請通過瀏覽器直接提交該數字。
注意:不要提交解答過程,或其它輔助說明類的內容。

import java.util.Arrays;
class PriceTag {
    int[] num = {1, 2, 5, 6, 8, 9, 0};
    int[] tst = {0, 1, 5, 3, 4, 2, 9, 7, 8, 6};
    //預設未使用為0
    int[] used = new int[7];
    static int[] res1 = new int[100];
    static int[] res2 = new int[100];
    static
int cnt = 0; public static void main(String[] args) { int[] a = new int[4]; new PriceTag().Permution(a, 0); //最佳應該是排序後利用二分查找出 //考慮資料量較小,暴力解出 for(int i=0;i<cnt;++i) for(int j=0;j<cnt;++j) { if(res2[i] + res2[j]==558&&res2[i]<0
) { System.out.println(res1[i]); return ; } } } void Permution(int[] a, int n) { if(n==4) { if(a[3]!=0) { tran(a); } return ; } for(int i=0 ; i<num.length ; ++i) { if(used[i]==0) { a[n] = num[i]; //used[i]=1;//註釋掉就是含重複的排列組合 Permution(a, n+1); used[i]=0; } } } void tran(int[] a) { int ret1 = 0; for (int i=0 ; i<4 ; ++i ) { ret1 += a[i]*Math.pow(10, 3-i); } int ret2 = 0; for (int i=0 ; i<4 ; ++i ) { ret2 += tst[a[i]]*Math.pow(10, i); } int d_val = ret1-ret2; if((d_val<-200&&d_val>-300)||(d_val<900&&d_val>800) ) { res1[cnt] = ret1; res2[cnt] = d_val; cnt++; } } }

輸出:

Compiling PriceTag.java.......
-----------OUTPUT-----------
8806
[Finished in 2.3s]