Jadual Kandungan
Contoh
Kaedah 2
Algoritma
Output
Kesimpulan
Rumah pembangunan bahagian belakang C++ Menyemak sama ada nombor yang dibentuk dengan menggabungkan elemen tatasusunan ialah nombor cincang

Menyemak sama ada nombor yang dibentuk dengan menggabungkan elemen tatasusunan ialah nombor cincang

Aug 25, 2023 pm 08:17 PM
menyambung elemen tatasusunan Nombor cincang

Menyemak sama ada nombor yang dibentuk dengan menggabungkan elemen tatasusunan ialah nombor cincang

Dalam soalan ini, kita diberikan tatasusunan integer. Kita perlu menggabungkan semua elemen menjadi integer dan menyemak sama ada ia adalah nombor Harshad.

Sebelum kita meneruskan penyelesaian, mari kita fahami nombor Harshad. Semua nombor ialah nombor Harshad, yang boleh dibahagikan dengan jumlah nombornya. Sebagai contoh, 12 ialah nombor Harshad kerana 12 boleh dibahagi dengan 3, iaitu hasil tambah 1+2.

Untuk menyelesaikan masalah ini, kita boleh menambah semua elemen tatasusunan dan kemudian menyemak sama ada hasilnya ialah nombor Harshad.

Pernyataan Masalah - Kami diberi pelbagai integer. Kita perlu menggabungkan semua elemen menjadi nombor dan menyemak sama ada nombor gabungan itu ialah nombor Harshad.

Contoh

Input – arr = {1, 35, 69, 60};

output-ya

Penjelasan - Nombor yang terhasil 1356960 boleh dibahagi dengan jumlahnya.

Input arr = {1, 65, 78, 1}

Output – Tidak

Penjelasan – Nombor gabungan 165781 tidak boleh dibahagikan dengan 28.

Input – arr = {1, 44}

output-ya

Penjelasan——144 boleh dibahagi dengan 9.

Kaedah 1

Kaedah ini menggabungkan semua elemen tatasusunan menjadi satu rentetan. Kami kemudian akan menggunakan kaedah stoi() untuk menukar rentetan gabungan kepada integer. Selepas itu, kita boleh menggunakan operator modulo untuk menyemak sama ada nombor boleh dibahagikan dengan jumlah digitnya.

Algoritma

  • Tentukan pembolehubah rentetan "gabungan" dan mulakan dengan rentetan kosong.

  • Lelaran pada tatasusunan integer. Tukar nombor kepada rentetan menggunakan kaedah to_string(). Selepas itu, tambahkannya pada pembolehubah "gabungan".

  • Tentukan 'jumlah' pembolehubah dan mulakannya kepada sifar untuk menyimpan jumlah nombor.

  • Gelung melalui rentetan gabungan dan simpan jumlah setiap nombor.

  • Tukar rentetan gabungan kepada integer menggunakan kaedah stoi(). Selepas itu, integer diambil modulo dan nilai Boolean dikembalikan berdasarkan hasilnya.

Contoh

#include <iostream>
#include <vector>
using namespace std;

// function to check whether the number formed by concatenating the elements of the array is a Harshad number or not
bool isHarshadNumber(vector<int> array){
   // store the concatenated number
   string combined = "";
   // Iterate over the array
   for (auto num : array){
      // Concatenate the string
      combined += to_string(num);
   }
   // Stores the sum of digits
   int sum = 0;
   // Calculate sum of digits
   for (int i = 0; i < combined.length(); i++)
      sum += (combined[i] - '0');
   // Check if n is divisible by the sum
   return stoi(combined) % sum == 0;
}
int main(){
   // Input
   vector<int> arr{1, 35, 69, 60};
   if (isHarshadNumber(arr))
      cout << "Yes, the number formed by concatenating the array element is a Harshad number";
   else
      cout << "No, the number formed by concatenating the array element is not a Harshad number";
   return 0;
}
Salin selepas log masuk

Output

Yes, the number formed by concatenating the array element is a Harshad number
Salin selepas log masuk

Kerumitan masa - O(N) kerana kami mengulangi rentetan.

Kerumitan ruang - O(1) kerana kami tidak menggunakan ruang tambahan.

Kaedah 2

Dalam kaedah ini, kami akan melakukan operasi modulo pada setiap blok kecil integer gabungan dan menyemak sama ada integer besar boleh dibahagikan dengan jumlahnya.

Algoritma

  • Tentukan pembolehubah rentetan "gabungan".

  • Lelaran pada tatasusunan integer dan simpan semua gabungan integer ke dalam pembolehubah 'gabungan'.

  • Simpan jumlah nombor dalam pembolehubah "jumlah"

  • Gunakan gelung untuk mengulangi rentetan "bergabung".

  • Tentukan pembolehubah 'semasa' dan mulakannya kepada sifar

  • Darab pembolehubah 'semasa' dengan 10 dan tambah nilai angka semasa. Kemudian, simpan nilai yang terhasil dalam pembolehubah 'semasa'.

  • Lakukan operasi modulo pada 'semasa' dan jumlah.

  • Apabila semua lelaran gelung selesai, kembalikan benar jika nilai pembolehubah "semasa" ialah sifar. Mengembalikan palsu jika nilai pembolehubah semasa adalah bukan sifar.

Contoh

#include <iostream>
#include <vector>
using namespace std;

// function to check whether the number formed by concatenating the elements of the array is a Harshad number or not
bool isHarshadNumber(vector<int> array){
   // store the concatenated number
   string combined = "";
   // Iterate over the array
   for (auto num : array){
      // Concatenate the string
      combined += to_string(num);
   }
   // Stores the sum of digits
   int sum = 0;
   // Calculate the sum of digits
   for (int i = 0; i < combined.length(); i++)
      sum += (combined[i] - '0');
   // to store the current integer
   int current = 0;
   for (int i = 0; i < combined.size(); i++) {
      // Calculate the current integer by multiplying 10 and adding the current digit
      current = current * 10 + (combined[i] - '0');
      // Check if the current integer is divisible by the sum
      current %= sum;
   }
   return current == 0;
}
int main(){
   // Input
   vector<int> arr{1, 35, 69, 0};
   if (isHarshadNumber(arr))
      cout << "Yes, the number formed by concatenating the array element is a Harshad number";
   else
      cout << "No, the number formed by concatenating the array element is not a Harshad number";
   return 0;
}
Salin selepas log masuk

Output

No, the number formed by concatenating the array element is not a Harshad number
Salin selepas log masuk

Kerumitan masa - O(N)

Kerumitan ruang - O(1)

Kesimpulan

Kami belajar dua cara berbeza untuk menyelesaikan masalah. Kaedah pertama hanya digunakan apabila tatasusunan mengandungi lebih sedikit elemen kerana kaedah stoi() mempunyai beberapa batasan apabila menukar rentetan kepada integer. Kaedah kedua adalah umum dan boleh digunakan untuk elemen tatasusunan N.

Atas ialah kandungan terperinci Menyemak sama ada nombor yang dibentuk dengan menggabungkan elemen tatasusunan ialah nombor cincang. 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 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 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)

Panduan Lengkap untuk Sambungan Pad Permainan Win11 Panduan Lengkap untuk Sambungan Pad Permainan Win11 Jan 02, 2024 pm 05:26 PM

Selepas mengemas kini kepada sistem win11 terkini, ramai pengguna tidak pasti cara menyambungkan pengawal untuk bermain permainan Atas sebab ini, kami telah membawakan anda tutorial terperinci tentang menyambungkan pengawal win11 hari ini. mari kita lihat cara mengendalikannya. Cara menyambungkan pengawal dalam win11: 1. Klik Mula di bawah dan kemudian masukkan Tetapan Windows untuk membuka "Panel Kawalan". 2. Selepas masuk, anda boleh mencari "Lihat peranti dan pencetak" untuk masuk. 3. Pada ketika ini anda boleh melihat maklumat tentang peranti pengawal dan hanya membuat sambungan. 4. Selepas sambungan berjaya, √ muncul, dan sambungan selesai.

pencetak win7 tidak boleh menyambung kod ralat 0x0000011b pencetak win7 tidak boleh menyambung kod ralat 0x0000011b Dec 26, 2023 pm 10:01 PM

Banyak kali kita perlu menggunakan komputer untuk menyambung ke pencetak untuk pelbagai operasi pencetakan, tetapi kadangkala sesetengah pengguna akan menghadapi masalah yang win7 tidak dapat menyambung ke pencetak 0x0000011b Berikut adalah penyelesaian khusus. Win7 tidak boleh menyambung ke pencetak 0x0000011b1. Kekunci pintasan "win+r", masukkan "regedit" 2. Cari laluan berikut "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Print" 3. Klik kanan untuk mencipta nilai baharu "DWORD ( 32-bit) nilai (D) dan Tetapkan nilai kepada 0. Namakan projek baharu "RpcAuthnLevelPri"

Bagaimana untuk menyemak butiran dan status sambungan rangkaian pada Windows 11 Bagaimana untuk menyemak butiran dan status sambungan rangkaian pada Windows 11 Sep 11, 2023 pm 02:17 PM

Untuk memastikan sambungan rangkaian anda berfungsi dengan betul atau untuk menyelesaikan masalah, kadangkala anda perlu menyemak butiran sambungan rangkaian pada Windows 11. Dengan melakukan ini, anda boleh melihat pelbagai maklumat termasuk alamat IP anda, alamat MAC, kelajuan pautan, versi pemacu dan banyak lagi, dan dalam panduan ini, kami akan menunjukkan kepada anda cara melakukannya. Bagaimana untuk mencari butiran sambungan rangkaian pada Windows 11? 1. Gunakan apl "Tetapan" dan tekan kekunci + untuk membuka Tetapan Windows. WindowsI Seterusnya, navigasi ke Rangkaian & Internet di anak tetingkap kiri dan pilih jenis rangkaian anda. Dalam kes kami, ini ialah Ethernet. Jika anda menggunakan rangkaian wayarles, pilih rangkaian Wi-Fi sebaliknya. Di bahagian bawah skrin anda sepatutnya melihat

Cara sambung jaga lemak badan skali Cara sambung jaga lemak badan skali Mar 07, 2024 pm 04:50 PM

Bagaimana untuk menyambungkan penimbang lemak badan yang disimpan? editor membawa kepada pengguna , pengguna yang berminat datang dan lihat! Cara menyambungkan skala simpan lemak badan 1. Mula-mula buka perisian simpan, pergi ke halaman utama dan klik [Saya] di sudut kanan bawah untuk memilih [Perkakasan Pintar] 2. Kemudian pada halaman Peranti Pintar Saya, klik butang Butang [Tambah Peranti] di tengah 3 , kemudian pilih peranti yang anda ingin tambah antara muka, pilih [Smart Body Fat/Weight Scale] 4. Kemudian pada halaman pemilihan model peranti, klik pilihan [keep body fat scale]. ; 5. Akhir sekali, dalam antara muka yang ditunjukkan di bawah, akhirnya [Tambah Sekarang] di bahagian bawah

Bagaimana untuk menyelesaikan sambungan rangkaian terhad dalam Windows 10 Bagaimana untuk menyelesaikan sambungan rangkaian terhad dalam Windows 10 Feb 19, 2024 pm 09:20 PM

Penyelesaian kepada Sambungan Rangkaian Terhad dalam Win10 Dengan perkembangan pesat teknologi, Internet telah menjadi bahagian yang amat diperlukan dalam kehidupan orang ramai. Walau bagaimanapun, kadangkala kita mungkin menghadapi beberapa masalah apabila menyambung ke Internet pada komputer menggunakan sistem pengendalian Windows 10, salah satunya adalah sambungan terhad. Dalam kes ini, kami tidak boleh mengakses halaman web, memuat turun fail atau menggunakan fungsi rangkaian seperti biasa. Jadi, adakah cara untuk menyelesaikan masalah ini? Artikel ini akan memperkenalkan anda kepada beberapa penyelesaian biasa. 1. Semak tetapan sambungan rangkaian Pertama, I

Apakah maksud kod ralat pencetak 0x0000011b? Apakah maksud kod ralat pencetak 0x0000011b? Feb 18, 2024 pm 10:02 PM

Apakah maksud 0x0000011b apabila menyambung kepada pencetak Pengguna sering menghadapi pelbagai kod ralat apabila menggunakan komputer, komputer riba atau peranti lain? Antaranya, 0x0000011b ialah kod ralat sambungan pencetak biasa. Jadi, apakah maksud menyambung pencetak 0x0000011b? Pertama, kita perlu memahami prinsip asas sambungan pencetak. Apabila kita perlu mencetak fail dari komputer, kita biasanya perlu menyambungkan pencetak ke komputer untuk pemindahan data antara kedua-duanya. Sambungan ini boleh dibuat melalui

Cara menyambungkan jam tangan OnePlus ke set kepala Bluetooth_Cara menyambung jam tangan OnePlus ke set kepala Bluetooth Cara menyambungkan jam tangan OnePlus ke set kepala Bluetooth_Cara menyambung jam tangan OnePlus ke set kepala Bluetooth Mar 23, 2024 pm 01:16 PM

1. Letakkan fon telinga dalam kotak fon telinga dan pastikan penutupnya terbuka Tekan dan tahan butang pada kotak untuk memasuki keadaan berpasangan fon telinga. 2. Hidupkan fungsi muzik jam tangan dan pilih fon kepala Bluetooth, atau pilih fon kepala Bluetooth dalam fungsi tetapan jam tangan. 3. Pilih set kepala pada jam tangan untuk berjaya dipasangkan.

Pencetak yang dikongsi tidak boleh menyambung ke pencetak Pencetak yang dikongsi tidak boleh menyambung ke pencetak Feb 22, 2024 pm 01:09 PM

Dengan perkembangan era digital, pencetak kongsi telah menjadi bahagian yang amat diperlukan dalam persekitaran pejabat moden. Walau bagaimanapun, kadangkala kita mungkin menghadapi masalah bahawa pencetak yang dikongsi tidak boleh disambungkan ke pencetak, yang bukan sahaja akan menjejaskan kecekapan kerja, tetapi juga menyebabkan beberapa siri masalah. Artikel ini bertujuan untuk meneroka sebab dan penyelesaian mengapa pencetak kongsi tidak boleh bersambung ke pencetak. Terdapat banyak sebab mengapa pencetak yang dikongsi tidak boleh menyambung ke pencetak, yang paling biasa ialah isu rangkaian. Jika sambungan rangkaian antara pencetak kongsi dan pencetak tidak stabil atau terganggu, operasi biasa tidak akan dapat dilakukan.

See all articles