

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);
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;
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); } }
Apabila saya menjalankan kod di atas, saya mendapat keputusan berikut:
21124
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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.