


Kira bilangan nombor N-digit yang tidak mempunyai awalan yang diberikan
Masalah di sini adalah untuk menentukan jumlah bilangan aksara '0' hingga '9' yang terkandung dalam rentetan panjang N, memberikan integer N dan awalan rentetan Tatasusunan pra[] supaya tiada satu pun rentetan ini mengandungi awalan yang disediakan. Tujuan artikel ini adalah untuk melaksanakan program yang mencari bilangan nombor N-digit yang tidak mempunyai awalan yang diberikan.
Dalam bahasa pengaturcaraan C, satu set rentetan berbeza dipanggil tatasusunan kerana tatasusunan ialah gabungan linear set kepingan data jenis yang serupa.
Seperti yang kita sedia maklum, rentetan ialah tatasusunan aksara demi aksara, satu dimensi yang berakhir dengan aksara kosong atau nol.
Contoh contoh 1
Mari kita andaikan bahawa input N = 2,
The given prefix, pre = {“1”}
Output obtained: 90
Penjelasan
Di sini, kecuali {"01","10","11", "12", "13", "14", "15", "16", "17", "18", " All Rentetan 2 digit kecuali 19", "21", "31", "41", "51", "61", "71", "81", "91"} adalah sah.
Contoh contoh 2
Mari kita ambil nilai input N = 3 sebagai contoh.
The given prefix, pre = {“56”}
Output obtained: 990
Penjelasan
Di sini, kecuali {"560", "561", "562", "563", "564", "565", "566", "567", "568", "569"} Semua rentetan kecuali 3 digit adalah sah.
Contoh Contoh 3
Mari kita lihat input N = 1,
The given prefix, pre = {“6”}
Output obtained: 9
Penjelasan
Kecuali {"6"}, semua rentetan 1 digit di sini adalah sah.
Pernyataan Masalah
Laksanakan program untuk mencari bilangan N digit yang tidak mempunyai awalan yang diberikan.
kaedah
Untuk mencari bilangan N digit tanpa awalan yang diberikan, kami menggunakan kaedah berikut.
Selesaikan masalah ini dan cari jalan untuk mencari N digit yang tidak mempunyai awalan yang diberikan
Memandangkan terdapat 10 pilihan aksara untuk setiap kedudukan dalam rentetan, terdapat (10N) rentetan berpotensi secara keseluruhan. Daripada mengira jumlah rentetan yang anda mahu, tolak jumlah rentetan yang anda tidak mahu. Menggabungkan awalan dengan aksara awal yang sama kepada awalan yang lebih panjang sebelum lelaran boleh mengakibatkan beberapa pendua dialih keluar.
Algoritma
Algoritma mengira untuk mencari N digit yang tidak mempunyai awalan yang diberikan
Langkah pertama − Mula
Langkah 2 - Tentukan fungsi untuk mengira jumlah bilangan rentetan panjang N yang tidak mengandungi awalan yang diberi
Langkah 3 - Kira jumlah bilangan rentetan
Langkah 4 - Buat tatasusunan dan pembilang a dan aCount dan masukkan awalan ini ke dalamnya
Langkah 5 − Buat tatasusunan rentetan awalan baharu
Langkah 6 - Lelaran untuk setiap aksara permulaan
Langkah 7 - Ulangi tatasusunan untuk mengira saiz minimum awalan
Langkah 8 - Sekarang letakkan semua awalan minimum ini ke dalam tatasusunan awalan baharu
Langkah 9 - Lelaran pada awalan baharu
Langkah 10 - Tolak rentetan yang tidak perlu
Langkah 11 − Cetak keputusan yang diperoleh
Langkah 12 − Berhenti
Contoh: program C
Ini ialah pelaksanaan program C bagi algoritma di atas untuk mencari bilangan N digit yang tidak mempunyai awalan yang diberikan.
#include <stdio.h> #include <math.h> #include <string.h> #define MAX_LENGTH 10 // Function to calculate total strings of length N without the given prefixes int totalStrings(int N, char pre[][MAX_LENGTH], int pre_Count){ // Calculate total strings present int total = (int)(pow(10, N) + 0.5); // Make an array and counter a and aCount respectively and insert these prefixes with same character in the array char a[10][MAX_LENGTH]; int aCount[10] = {0}; for (int i = 0; i < pre_Count; i++) { int index = pre[i][0] - '0'; strcpy(a[index] + aCount[index] * MAX_LENGTH, pre[i]); aCount[index]++; } // Make a new array of prefixes strings char new_pre[pre_Count][MAX_LENGTH]; int new_pre_count = 0; // Iterating for each of the starting //character for (int x = 0; x < 10; x++){ int m = N; // Iterate over the array to calculate minimum size prefix for (int j = 0; j < aCount[x]; j++){ int p_length = strlen(a[x] + j * MAX_LENGTH); m = (m < p_length) ? m : p_length; } // now take all these minimum prefixes in the new array of prefixes for (int j = 0; j < aCount[x]; j++){ int p_length = strlen(a[x] + j * MAX_LENGTH); if (p_length <= m){ strcpy(new_pre[new_pre_count], a[x] + j * MAX_LENGTH); new_pre_count++; } } } // Iterating through the new prefixes for (int i = 0; i < new_pre_count; i++){ // Subtract the unwanted strings total -= (int)(pow(10, N - strlen(new_pre[i])) + 0.5); } return total; } // The main function int main(){ int N = 5; char pre[][MAX_LENGTH] = {"1", "0", "2"}; int pre_Count = sizeof(pre) / sizeof(pre[0]); printf("%d\n", totalStrings(N, pre, pre_Count)); return 0; }
Output
70000
KESIMPULAN
Begitu juga, kita boleh mencari bilangan N digit yang tidak mempunyai awalan yang diberikan.
Dalam siaran ini, cabaran mendapatkan program untuk mencari kiraan N-digit yang tidak mempunyai awalan yang diberikan telah diselesaikan.
C kod pengaturcaraan disediakan di sini bersama-sama dengan algoritma untuk mencari kiraan nombor N-digit yang tidak mempunyai awalan yang diberikan.
Atas ialah kandungan terperinci Kira bilangan nombor N-digit yang tidak mempunyai awalan yang diberikan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Mengintegrasikan XML dalam projek C boleh dicapai melalui langkah-langkah berikut: 1) Menguraikan dan menghasilkan fail XML menggunakan PuGixML atau Perpustakaan TinyXML, 2) Pilih kaedah DOM atau SAX untuk parsing, 3) mengendalikan nod bersarang dan sifat berbilang level,

XML digunakan dalam C kerana ia menyediakan cara yang mudah untuk menyusun data, terutamanya dalam fail konfigurasi, penyimpanan data dan komunikasi rangkaian. 1) Pilih perpustakaan yang sesuai, seperti TinyXML, PugixML, RapidXML, dan tentukan mengikut keperluan projek. 2) Memahami dua cara parsing dan generasi XML: DOM sesuai untuk akses dan pengubahsuaian yang kerap, dan SAX sesuai untuk fail besar atau data streaming. 3) Apabila mengoptimumkan prestasi, TinyXML sesuai untuk fail kecil, PuGixML berfungsi dengan baik dalam ingatan dan kelajuan, dan RapidXML sangat baik dalam memproses fail besar.

Perbezaan utama antara C# dan C ialah pengurusan memori, pelaksanaan polimorfisme dan pengoptimuman prestasi. 1) C# menggunakan pemungut sampah untuk mengurus memori secara automatik, sementara C perlu diuruskan secara manual. 2) C# menyedari polimorfisme melalui antara muka dan kaedah maya, dan C menggunakan fungsi maya dan fungsi maya murni. 3) Pengoptimuman prestasi C# bergantung kepada struktur dan pengaturcaraan selari, manakala C dilaksanakan melalui fungsi inline dan multithreading.

Kaedah DOM dan SAX boleh digunakan untuk menghuraikan data XML dalam C. 1) DOM Parsing beban XML ke dalam ingatan, sesuai untuk fail kecil, tetapi mungkin mengambil banyak ingatan. 2) Parsing Sax didorong oleh peristiwa dan sesuai untuk fail besar, tetapi tidak dapat diakses secara rawak. Memilih kaedah yang betul dan mengoptimumkan kod dapat meningkatkan kecekapan.

C digunakan secara meluas dalam bidang pembangunan permainan, sistem tertanam, urus niaga kewangan dan pengkomputeran saintifik, kerana prestasi dan fleksibiliti yang tinggi. 1) Dalam pembangunan permainan, C digunakan untuk rendering grafik yang cekap dan pengkomputeran masa nyata. 2) Dalam sistem tertanam, pengurusan memori dan keupayaan kawalan perkakasan C menjadikannya pilihan pertama. 3) Dalam bidang urus niaga kewangan, prestasi tinggi C memenuhi keperluan pengkomputeran masa nyata. 4) Dalam pengkomputeran saintifik, pelaksanaan algoritma yang cekap C dan keupayaan pemprosesan data sepenuhnya dicerminkan.

C tidak mati, tetapi telah berkembang dalam banyak bidang utama: 1) pembangunan permainan, 2) pengaturcaraan sistem, 3) pengkomputeran berprestasi tinggi, 4) pelayar dan aplikasi rangkaian, C masih pilihan arus perdana, menunjukkan senario vitalitas dan aplikasi yang kuat.

Perbezaan utama antara C# dan C ialah sintaks, pengurusan memori dan prestasi: 1) C# sintaks adalah moden, menyokong Lambda dan Linq, dan C mengekalkan ciri -ciri C dan menyokong templat. 2) C# secara automatik menguruskan memori, C perlu diuruskan secara manual. 3) Prestasi C lebih baik daripada C#, tetapi prestasi C# juga dioptimumkan.

Anda boleh menggunakan perpustakaan TinyXML, PuGixML, atau libxml2 untuk memproses data XML dalam C. 1) Parse XML Files: Gunakan kaedah DOM atau SAX, DOM sesuai untuk fail kecil, dan SAX sesuai untuk fail besar. 2) Menjana fail XML: Tukar struktur data ke dalam format XML dan tulis ke fail. Melalui langkah -langkah ini, data XML dapat diuruskan dan dimanipulasi dengan berkesan.


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

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

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.

Dreamweaver Mac版
Alat pembangunan web visual

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa
