Jadual Kandungan
Kandungan soalan
Penyelesaian
Rumah Java Soalan ProjectEuler 17: Saya menukar baris kod ini dan jawapan saya berubah secara dramatik, walaupun saya fikir ia sepatutnya berfungsi

Soalan ProjectEuler 17: Saya menukar baris kod ini dan jawapan saya berubah secara dramatik, walaupun saya fikir ia sepatutnya berfungsi

Feb 13, 2024 pm 08:51 PM

editor php Apple menghadapi situasi yang menarik dalam ProjectEuler isu 17. Selepas dia menukar satu baris kod, dia mendapati jawapannya berubah secara mendadak, walaupun dia fikir kod itu harus berfungsi dengan betul. Soalan ini menimbulkan rasa ingin tahunya, dan dia mula meneroka sebab-sebabnya dan mencari penyelesaian. Kisah ini penuh dengan cabaran dan pemikiran, membuatkan orang ramai menantikan jawapan editor.

Kandungan soalan

Saya sedang mengusahakan projek euler soalan 17. Saya harus menulis program untuk mengira jumlah bilangan aksara dalam nombor bertulis 1-1000. Anda mengabaikan ruang dan sempang. Menurut huraian masalah, beratus-ratus nombor termasuk "dan" (tiga ratus empat puluh dua). Kod saya berfungsi dalam kebanyakan kes kecuali gandaan 100 (apabila ia mengira "jumlah" tambahan). Sebagai contoh, kira 600 sebagai "enam ratus dan." Ini menyebabkan jawapan saya menyimpang daripada 27 (3 daripada 100 digit). Ini hampir penyelesaian yang betul:

string[] nums = {"",
                 "one",
                 "two",
                 "three",
                 "four",
                 "five",
                 "six",
                 "seven",
                 "eight",
                 "nine",
                 "ten",
                 "eleven",
                 "twelve",
                 "thirteen",
                 "fourteen",
                 "fifteen",
                 "sixteen",
                 "seventeen",
                 "eighteen",
                  "nineteen"};
string[] ten = {"",
                "",
                "twenty",
                "thirty",
                "forty",
                "fifty",
                "sixty",
                "seventy",
                "eighty",
                "ninety"};
int sum = 0;
map<integer, integer> ones = new hashmap<>();
map<integer, integer> teens = new hashmap<>();
map<integer, integer> tens = new hashmap<>();
for (int i = 0; i < 10; i++) {
    ones.put(i, nums[i].length());
}
for (int i = 10; i < nums.length; i++) {
    teens.put(i, nums[i].length());
}
for (int i = 0; i < ten.length; i++) {
    tens.put(i * 10, ten[i].length());
}
for (int i = 1; i < 1000; i++) {
    int num = 0;
    int n = i % 100;
    if (n > 19 || n < 10) {
        num += ones.get(n % 10);
        num += tens.get(n - n % 10);
    }
    else {
        num += teens.get(n);
    }
    num += i > 99 ? "hundredand".length() : 0;
    num += ones.get(i / 100);
    system.out.println(num + " " + i);
    sum += num;
}
sum += ("onethousand").length();
// actual is 21124
system.out.println(sum);
Salin selepas log masuk

Ini menghasilkan output 21151, iaitu 27 berbeza daripada output jangkaan 21124. Pembolehubah num digunakan untuk tujuan nyahpepijat.

Saya cuba menukar salah satu baris gelung dan menambah pernyataan tambahan:

num += i>99 ? "hundred".length() : 0;
num += i%100==0 ? 3 : 0;
Salin selepas log masuk

Selepas menjalankan versi yang dikemas kini ini, outputnya ialah 18487. Saya tidak pasti mengapa perbezaan ini begitu ketara dan ingin memahami dari mana asalnya. Saya mula-mula fikir ia adalah kerana pengendali ternary, kerana pengetahuan saya tentangnya adalah terhad. Selain itu, sebarang cadangan untuk menjadikan kod lebih cekap adalah dialu-alukan. Saya ingin memasukkan sum-27 sebelum mencetak, tetapi saya rasa itu agak menipu :). Terima kasih!

Penyelesaian

Seperti yang orang lain katakan dalam ulasan kepada soalan anda, masalah anda ialah bagaimana kod anda mengendalikan nombor yang berganda 100. Anda sentiasa menambah seratus dan jangan sekali-kali hanya seratusum>. Malah, anda menyatakan diri anda dalam soalan anda:

Dalam kod di bawah, saya menggunakan pernyataan if eksplisit - bukannya pengendali ternari - kerana saya percaya ia menjadikan kod lebih mudah difahami semasa membaca. Sila ambil perhatian bahawa ini adalah satu-satunya perubahan yang saya buat pada kod yang disiarkan dalam soalan anda.

import java.util.hashmap;
import java.util.map;

public class myclass {
    public static void main(string args[]) {
        string[] nums = {"",
                         "one",
                         "two",
                         "three",
                         "four",
                         "five",
                         "six",
                         "seven",
                         "eight",
                         "nine",
                         "ten",
                         "eleven",
                         "twelve",
                         "thirteen",
                         "fourteen",
                         "fifteen",
                         "sixteen",
                         "seventeen",
                         "eighteen",
                         "nineteen"};
        string[] ten = {"",
                        "",
                        "twenty",
                        "thirty",
                        "forty",
                        "fifty",
                        "sixty",
                        "seventy",
                        "eighty",
                        "ninety"};
        int sum = 0;
        map<integer, integer> ones = new hashmap<>();
        map<integer, integer> teens = new hashmap<>();
        map<integer, integer> tens = new hashmap<>();
        for (int i = 0; i < 10; i++) {
            ones.put(i, nums[i].length());
        }
        for (int i = 10; i < nums.length; i++) {
            teens.put(i, nums[i].length());
        }
        for (int i = 0; i < ten.length; i++) {
            tens.put(i * 10, ten[i].length());
        }
        for (int i = 1; i < 1000; i++) {
            int num = 0;
            int n = i % 100;
            if (n > 19 || n < 10) {
                num += ones.get(n % 10);
                num += tens.get(n - n % 10);
            }
            else {
                num += teens.get(n);
            }
            if (i > 99) {
                num += n == 0 ? "hundred".length() : "hundredand".length();
            }
            num += ones.get(i / 100);
            sum += num;
//            system.out.printf("%2d %3d %5d%n", num, i, sum);
        }
        sum += ("onethousand").length();
        // actual is 21124
        system.out.println(sum);
    }
}
Salin selepas log masuk

Apabila saya menjalankan kod di atas, saya mendapat keputusan berikut:

21124
Salin selepas log masuk

Dalam kod soalan anda, anda menulis (dalam komen kod) bahawa ini adalah jawapan yang diharapkan.

Atas ialah kandungan terperinci Soalan ProjectEuler 17: Saya menukar baris kod ini dan jawapan saya berubah secara dramatik, walaupun saya fikir ia sepatutnya berfungsi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)