【问题标题】:I have wrong answer for project Euler#8我对 Euler#8 项目有错误的答案
【发布时间】:2015-03-25 10:12:45
【问题描述】:

我不知道为什么这个问题错了。我搜索谷歌虽然我看不懂。谢谢你的帮助:)。问题是=

1000 位数字中相邻的四个数字 最大的产品是 9 × 9 × 8 × 9 = 5832。

73167176531330624919225119674426574742355349194934 96983520312774506326239578318016984801869478851843 85861560789112949495459501737958331952853208805511 12540698747158523863050715693290963295227443043557 66896648950445244523161731856403098711121722383113 62229893423380308135336276614282806444486645238749 30358907296290491560440772390713810515859307960866 70172427121883998797908792274921901699720888093776 65727333001053367881220235421809751254540594752243 52584907711670556013604839586446706324415722155397 53697817977846174064955149290862569321978468622482 83972241375657056057490261407972968652414535100474 82166370484403199890008895243450658541227588666881 16427171479924442928230863465674813919123162824586 17866458359124566529476545682848912883142607690042 24219022671055626321111109370544217506941658960408 07198403850962455444362981230987879927244284909188 84580156166097919133875499200524063689912560717606 05886116467109405077541002256983155200055935729725 71636269561882670428252483600823257530420752963450

找出 1000 位数字中相邻的 13 个数字 最伟大的产品。这个产品有什么价值?

public static void main(String[] args) 
{
    String str= "73167176531330624919225119674426574742355349194934"+
                "96983520312774506326239578318016984801869478851843"+
                "85861560789112949495459501737958331952853208805511"+
                "12540698747158523863050715693290963295227443043557"+
                "66896648950445244523161731856403098711121722383113"+
                "62229893423380308135336276614282806444486645238749"+
                "30358907296290491560440772390713810515859307960866"+
                "70172427121883998797908792274921901699720888093776"+
                "65727333001053367881220235421809751254540594752243"+
                "52584907711670556013604839586446706324415722155397"+
                "53697817977846174064955149290862569321978468622482"+
                "83972241375657056057490261407972968652414535100474"+
                "82166370484403199890008895243450658541227588666881"+
                "16427171479924442928230863465674813919123162824586"+
                "17866458359124566529476545682848912883142607690042"+
                "24219022671055626321111109370544217506941658960408"+
                "07198403850962455444362981230987879927244284909188"+
                "84580156166097919133875499200524063689912560717606"+
                "05886116467109405077541002256983155200055935729725"+
                "71636269561882670428252483600823257530420752963450";
    char chr[] = new char[str.length()];
    chr=str.toCharArray();
    long bignumber=0;
    for (int i = 0; i < chr.length; i++) 
    {
        if(i<=986)
        {
            if(chr[i+0]*chr[i+1]*chr[i+2]*chr[i+3]*chr[i+4]*chr[i+5]*chr[i+6]*chr[i+7]*chr[i+8]*chr[i+9]*chr[i+10]*chr[i+11]*chr[i+12]>bignumber)
            {
                bignumber=chr[i+0]*chr[i+1]*chr[i+2]*chr[i+3]*chr[i+4]*chr[i+5]*chr[i+6]*chr[i+7]*chr[i+8]*chr[i+9]*chr[i+10]*chr[i+11]*chr[i+12];
            }
        }
    }
    System.out.println(bignumber);
}

【问题讨论】:

  • 您在这里按字符值进行比较,而不是按数字值进行比较。最简单的方法就是从每个 chr[i+n] 中减去 '0',尤其是在将其重构为循环时。
  • 感谢您的帮助:)

标签: java string


【解决方案1】:

您是在乘以字符的数值而不是乘以数字。

chr[i+x] 替换为Character.getNumericValue(chr[i+x])

除此之外,对每 13 位执行两次乘法是很浪费的。执行一次乘法并将结果存储在一个变量中,以便您可以重复使用它。

更好的是,在每次迭代中,您可以获取上一次迭代的结果,除以上一次迭代的第一个数字,然后乘以当前迭代的最后一个数字。这将为您节省许多乘法。编辑:实际上这种优化只有在数字中没有零的情况下才有效,所以你可以忘记它。

【讨论】:

    【解决方案2】:

    产品是 23514624000
    序列是 5576689664895

    代码是 -

    public class Test{
    
         public static void main(String []args){
            String str= "73167176531330624919225119674426574742355349194934"+
                    "96983520312774506326239578318016984801869478851843"+
                    "85861560789112949495459501737958331952853208805511"+
                    "12540698747158523863050715693290963295227443043557"+
                    "66896648950445244523161731856403098711121722383113"+
                    "62229893423380308135336276614282806444486645238749"+
                    "30358907296290491560440772390713810515859307960866"+
                    "70172427121883998797908792274921901699720888093776"+
                    "65727333001053367881220235421809751254540594752243"+
                    "52584907711670556013604839586446706324415722155397"+
                    "53697817977846174064955149290862569321978468622482"+
                    "83972241375657056057490261407972968652414535100474"+
                    "82166370484403199890008895243450658541227588666881"+
                    "16427171479924442928230863465674813919123162824586"+
                    "17866458359124566529476545682848912883142607690042"+
                    "24219022671055626321111109370544217506941658960408"+
                    "07198403850962455444362981230987879927244284909188"+
                    "84580156166097919133875499200524063689912560717606"+
                    "05886116467109405077541002256983155200055935729725"+
                    "71636269561882670428252483600823257530420752963450";
        char chr[] = new char[str.length()];
        chr=str.toCharArray();
        long product = 0;
        String digits = "";
        for (int i = 0; i < chr.length - 13; i++) 
        {   
            long product1 = (long)Character.getNumericValue(chr[i+0])*Character.getNumericValue(chr[i+1])*Character.getNumericValue(chr[i+2])*Character.getNumericValue(chr[i+3])*Character.getNumericValue(chr[i+4])*Character.getNumericValue(chr[i+5])*Character.getNumericValue(chr[i+6])*Character.getNumericValue(chr[i+7])*Character.getNumericValue(chr[i+8])*Character.getNumericValue(chr[i+9])*Character.getNumericValue(chr[i+10])*Character.getNumericValue(chr[i+11])*Character.getNumericValue(chr[i+12]);
    
            if(product < product1)
                {
                    product = product1;
                    digits = ""+chr[i+0]+chr[i+1]+chr[i+2]+chr[i+3]+chr[i+4]+chr[i+5]+chr[i+6]+chr[i+7]+chr[i+8]+chr[i+9]+chr[i+10]+chr[i+11]+chr[i+12];
                }
        }
        System.out.println(product);
        System.out.println(digits);
    
         }
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多