C# :: Aufgabe #366 :: Lösung #6

6 Lösungen Lösungen öffentlich
#366

Zweierpotenz (Power Of Two)

Anfänger - C# von JKooP - 06.03.2021 um 11:51 Uhr
Erstelle eine Methode/Funktion, mit der man bestimmen kann,
ob die übergebene Zahl als Ganzzahl- Potenz (Integer) zur Basis 2 geschrieben werden kann.

Beispiele:

Zahl: 1 => true
Lösung: 0, denn 2 hoch 0 = 1

Zahl: 16 => true
Lösung: 4, denn 2 hoch 4 = 16

Zahl: 3 => false
Lösung: keine, da keine Ganzzahl zur Basis 2 die Zahl 3 ergibt

Für Fortgeschrittene:
Die Aufgabe ohne Zuhilfenahme der eingebauten Logarithmusfunktionen lösen.

Viel Spaß
#6
vote_ok
von JKooP (18090 Punkte) - 31.03.2021 um 18:37 Uhr
NET 5.x; C# 9.x; VS-2019

Quellcode ausblenden C#-Code
using System;
Console.WriteLine(IsPowerOfTwo(17));


Lösung 1 (Log):
Quellcode ausblenden C#-Code
static bool IsPowerOfTwo(int n) => Math.Round(Math.Log(n, 2), 10) % 1 == 0;


Lösung 2:
Quellcode ausblenden C#-Code
static bool IsPowerOfTwo(int n)
{
    if (n == 0) return false;
    while (n % 2 == 0) n /= 2;
    return n == 1;
}

Kommentare:

Für diese Lösung gibt es noch keinen Kommentar

Bitte melden Sie sich an um eine Kommentar zu schreiben.
Kommentar schreiben
1824567

Du scheinst einen AdBlocker zu nutzen. Ich würde mich freuen, wenn du ihn auf dieser Seite deaktivierst und dich davon überzeugst, dass die Werbung hier nicht störend ist.