project euler113

project euler 113

对于1个数字,如果他数位不减或者不增称为bouncy number,比如1233,33210。统计1~10^100中的bouncy number
 
思路:分为两种计算

1.这个数中只出现了一个数字,那么对于i位的数字有9种,故总计有9 * 100种

2.这个数中至少出现两个数字,分别按位数计算不减的数和不增的数
以不减的数为例,枚举首数字j和尾数字k(j < k),
j = a1 <= a2 <= a3 <= a4 <= a5 <= … <= am = k
令x1 = a2 - a1,x2 = a3 - a2, x3 = a4 - a3, …, xm - 1 = am - am-1。
x1 + x2 + x3 + … + xm-1 = k - j 解不定方程的解,C(k - j + m - 2, k - j)
不增的数同理
import java.util.*;
import java.io.*;
import java.math.BigDecimal;
import java.math.BigInteger;

public class Main {
    BigInteger bi(int x) {
        return BigInteger.valueOf(x);
    }
    BigInteger comb(int n, int m) {
        BigInteger ret = bi(1);
        for (int i = n; i >= n - m + 1; -- i) ret = ret.multiply(bi(i));
        for (int i = 1; i <= m; ++ i) ret = ret.divide(bi(i));
        return ret;
    }
    void solve() {
        int n = 100;
        BigInteger ans = bi(9 * n);
        for (int i = 2; i <= n; ++ i) {
            for (int j = 1; j <= 8; ++ j)
                for (int k = j + 1; k <= 9; ++ k) {
                    ans = ans.add(comb(k - j + i - 2, k - j));
                }
        }
        for (int i = 2; i <= n; ++ i) {
            for (int j = 1; j <= 9; ++ j) 
                for (int k = 0; k <= j - 1; ++ k) {
                    ans = ans.add(comb(j - k + i - 2, j - k));
                }
        }
        System.out.println(ans);
     }
    FastScanner cin;
    PrintWriter out;
    void run() {
        cin = new FastScanner();
        out = new PrintWriter(System.out);
        solve();
        out.flush();
    }
    class FastScanner {
        BufferedReader br;
        StringTokenizer st;
        boolean hasNext;
        
        public FastScanner() {
            br = new BufferedReader(new InputStreamReader(System.in));
            hasNext = true;
        }

//        public FastScanner(String s) {
//            try {
//                br = new BufferedReader(new FileReader(s));
//            } catch (FileNotFoundException e) {
//                // TODO Auto-generated catch block
//                e.printStackTrace();
//            }
//            hasNext = true;
//        }

        public String nextToken() {
            while (st == null || !st.hasMoreTokens()) {
                try {
                    st = new StringTokenizer(br.readLine());
                } catch (Exception e) {
                    hasNext = false;
                    return "##";
                }
            }
            return st.nextToken();
        }
        String next = null;
        public boolean hasNext() {
            next = nextToken();
            return hasNext;
        }
        public int nextInt() {
            if (next == null) next = nextToken();
            String more = next;
            next = null;
            return Integer.parseInt(more);
        }
        public long nextLong() {
            return Long.parseLong(nextToken());
        }

        public double nextDouble() {
            return Double.parseDouble(nextToken());
        }
    }
    public static void main(String[] args) {
        new Main().run();
    }
}

 

 

posted @ 2017-10-11 23:48  zd11024  阅读(199)  评论(0编辑  收藏  举报