Rumah > hujung hadapan web > tutorial js > Program JavaScript untuk menyemak sama ada nombor yang diberikan ialah kuasa 2

Program JavaScript untuk menyemak sama ada nombor yang diberikan ialah kuasa 2

王林
Lepaskan: 2023-09-07 19:13:02
ke hadapan
1324 orang telah melayarinya

JavaScript 程序检查给定数字是否是 2 的幂

Jika nombor yang diberikan dijana dengan hanya mendarab 2, maka nombor itu adalah kuasa 2. Dalam tutorial ini, kita akan belajar untuk menyemak sama ada nombor yang diberikan ialah kuasa 2. Di sini kita akan melihat 5 cara berbeza untuk menyemak sama ada nombor yang diberikan ialah kuasa 2.

Gunakan kaedah Math.pow()

Dalam JavaScript, nombor boleh mengandungi sehingga 64 bit. Oleh itu, kita boleh menggunakan gelung for dan kaedah Math.pow() untuk mencari 2 dinaikkan kepada kuasa 1 hingga 64. Untuk gelung, kita boleh membandingkan 2 yang dinaikkan kepada kuasa ke dengan nombor. Jika ia sepadan dengan nombor, kami mengembalikan benar jika tidak, kami mengembalikan palsu apabila gelung ditamatkan.

Tatabahasa

Pengguna boleh menggunakan kaedah gelung for dan Math.pow() mengikut sintaks di bawah untuk menyemak sama ada nombor itu boleh dibahagi dengan 2.

for () {
   if (Math.pow(2, i) == num) {
      return true;
   }
}        
Salin selepas log masuk

Algoritma

  • Langkah 1 - Gunakan gelung for dan ulangi nombor i=1 hingga i=64.

  • Langkah 2 - Dalam gelung for, gunakan kaedah Math.pow() untuk menaikkan 2 kepada kuasa i.

  • Langkah 3 - Bandingkan 2 yang dinaikkan kepada kuasa i dengan nombor. Jika ada padanan, kembali benar.

  • Langkah 4 - Jika gelung for ditamatkan tanpa mengembalikan benar, kembalikan palsu.

Contoh 1

Dalam contoh di bawah, kami menggunakan kaedah di atas untuk menyemak sama ada nombor yang diberikan ialah kuasa 2. Dalam output, pengguna boleh melihat bahawa fungsi checkPowOf2() mengembalikan benar atau salah berdasarkan sama ada nombor itu kuasa atau tidak.

<html>
<body>
   <h3> Using the <i> Math.pow() method </i> to check whether the given number is a power of 2 or not </h3>
   <div id="output"> </div>
   <script>
      let output = document.getElementById('output');
      let num1 = 342434535;
      let num2 = 2048;
      function checkPowOf2(num) {
         for (let i = 0; i < 64; i++) {
            if (Math.pow(2, i) == num) {
               return true;
            }
         }
         return false;
      }
      output.innerHTML += "The " + num1 + " is a power of 2 :- " + checkPowOf2(num1) + " <br> ";
      output.innerHTML += "The " + num2 + " is a power of 2 :- " + checkPowOf2(num2) + " <br> ";
   </script>
</body>
</html>
Salin selepas log masuk

Gunakan kaedah Math.log()

Kita boleh mengambil logaritma nombor asas 2. Jika nombor itu adalah integer, ia adalah kuasa 2.

Tatabahasa

Pengguna boleh menggunakan kaedah Math.log() mengikut sintaks di bawah untuk menyemak sama ada nombor itu kuasa 2.

let log = Math.log(number) / Math.log(2);
let isInteger = parseInt(log) == log;
Salin selepas log masuk

Contoh 2

Dalam contoh di bawah, kita mula-mula mengambil logaritma asas 2 nombor, dan kemudian menggunakan kaedah parseInt() untuk mengekstrak integer daripada logaritma Jika ia dibandingkan dengan logaritma, fungsi itu kembali benar.

<html>
<body>
   <h3> Using the <i> Math.log() method </i> to check whether the given number is a power of 2 or not </h3>
   <div id="output"> </div>
   <script>
      let output = document.getElementById('output');
      let number1 = 1024;
      let number2 = 3454;
      function checkPowOf2(number) {
      
         // get a log of the number on base 2
         let log = Math.log(number) / Math.log(2);
         
         // If the log is an integer, return true.
         if (parseInt(log) == log) {
            return true;
         }
         return false;
      }
      output.innerHTML += "The " + number1 + " is a power of 2 :- " + checkPowOf2(number1) + " <br> ";
      output.innerHTML += "The " + number2 + " is a power of 2 :- " + checkPowOf2(number2) + " <br> ";
   </script>
</body>
</html>
Salin selepas log masuk

Ditentukan dengan mengira set Bit

Jika nombor adalah kuasa 2, ia hanya mengandungi satu set bit. Jadi, kita boleh semak setiap digit nombor satu persatu. Jika kita mendapat bit set pertama, kita tetapkan isSetBit kepada benar. Selepas itu, jika kita menetapkan bit sekali lagi, kita boleh mengatakan bahawa nombor itu bukan kuasa 2.

Tatabahasa

Pengguna boleh mengikut sintaks di bawah untuk menentukan sama ada nombor itu adalah kuasa 2 dengan mengira bilangan digit yang ditetapkan.

while (number) { 
   if (isSetBit) { 
      return false;
   } 
   else if (number & 1 == 1) { 
      isSetBit = true; 
   } 
   number = number >> 1; 
}
Salin selepas log masuk

Algoritma

  • Langkah 1 - Gunakan gelung sementara untuk lelaran apabila nombor itu tidak sama dengan 0.

  • Langkah 2 - Semak sama ada nilai pembolehubah "isSetBit" adalah benar;

  • Langkah 3 - Jika nilai pembolehubah isSetBit adalah palsu dan bit semasa ialah bit set, maka tukar nilai pembolehubah isSetBit kepada benar.

    < /里>
  • Langkah 4 - Gerakkan nombor ke kanan sebanyak 1.

Contoh 3

Dalam contoh di bawah, kami menggunakan gelung sementara untuk mengulang nombor dan menyemak setiap digit nombor itu. Jika kita mendapat bit set kedua dalam nombor, kita akan mengembalikan palsu.

<html>
<body>
   <h3> Counting the <i> set bits </i> to check whether the given number is a power of 2 or not </h3>
   <div id="output"> </div>
   <script>
      let output = document.getElementById('output');
      let number1 = 2048 * 2 * 2 * 2;
      let number2 = 87907;
      function checkPowOf2(number) {
         let isSetBit = false;
         if (number) {
            while (number) {
               if (isSetBit) {
                  return false;
               } else if (number & 1 == 1) {
                  isSetBit = true;
               }
               number = number >> 1;
            }
            return true;
         }
         return false;
      }
      output.innerHTML += "The " + number1 + " is a power of 2 :- " + checkPowOf2(number1) + " <br> ";
      output.innerHTML += "The " + number2 + " is a power of 2 :- " + checkPowOf2(number2) + " <br> ";
   </script>
</body>
</html>
Salin selepas log masuk

Gunakan pengendali “&”

Jika nombor adalah kuasa 2, bit paling kiri mengandungi hanya 1. Jika kita menolak 1 daripada kuasa 2, bit paling kiri nombor mengandungi 0 dan bit lain mengandungi 1. Jadi jika kita melakukan operasi "&" antara n dan n-1, ia akan sentiasa mengembalikan sifar untuk semua nombor yang sama dengan kuasa 2.

Tatabahasa

Pengguna boleh menggunakan operator ‘&’ seperti dalam sintaks di bawah untuk menyemak sama ada nombor yang diberikan ialah kuasa 2.

let isPowerOf2 = number && !(number & number - 1)
Salin selepas log masuk

Contoh 4

Dalam contoh di bawah, kami mula-mula menyemak sama ada nombor dalam pernyataan if bukan sifar. Kami kemudian menyemak sama ada "n & n-1" adalah sama dengan 0 untuk melihat sama ada nombor itu adalah kuasa 2.

<html>
<body>
   <h3> Using the <i> & operator </i> to check whether the given number is a power of 2 or not </h3>
   <div id="output"> </div>
   <script>
      let output = document.getElementById('output');
      let number1 = 1024 * 2 * 2 * 2;
      let number2 = 409540;
      function checkPowOf2(number) {
         if (number && !(number & number - 1)) {
            return true;
         }
         return false;
      }
      output.innerHTML += "The " + number1 + " is a power of 2 :- " + checkPowOf2(number1) + " <br> ";
      output.innerHTML += "The " + number2 + " is a power of 2 :- " + checkPowOf2(number2) + " <br> ";
   </script>
</body>
</html>
Salin selepas log masuk

Atas ialah kandungan terperinci Program JavaScript untuk menyemak sama ada nombor yang diberikan ialah kuasa 2. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:tutorialspoint.com
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan