Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


veckans nöt #2

Postades av 2004-11-03 09:22:15 - Roger Alsing, i forum systemutveckling generellt, Tråden har 9 Kommentarer och lästs av 1178 personer

jag har en liten grej som är ungefär som pelles problem.

skriv en så kort rutin som möjligt (i valfritt språk) som returnerar true på 1,2,4,8,16,32,64,.... osv (binära värden) men false på allt annat.


//Roger


Svara

Sv: veckans nöt #2

Postades av 2004-11-03 09:50:18 - Andreas Håkansson

Roger,

Då du inte anger vilken typ av tal det ska handla om så utgick jag från en helt vanlig <b>int</b> och då kan man göra på följande sätt

[C#]

public bool IsEven(int tal)
{
    return (((tal >> 32) & 1 ) == 0);
}


Supersnabb eftersom den använder bitoperatorer (shift och and).

<b>EDIT: </b> Ärch tänkte juh helt fel... sååå trött =) Tänkte på jämn&udda.. såg sen vad du skrev.


Svara

Sv: veckans nöt #2

Postades av 2004-11-03 09:51:45 - Christer Thun

Hyfsat kort, men är det för långt skyller jag allt på delphi :)

function test(a:real):boolean;
begin
   if a <= 1 then 
     result := (a=1)
   else
     result := test(a/2);
end;


Svara

Sv: veckans nöt #2

Postades av 2004-11-03 09:52:05 - Martin Adrian

bool powerof2(int number) {
return !(number & (number - 1))
}


Svara

Sv: veckans nöt #2

Postades av 2004-11-03 09:59:19 - Roger Alsing

Andreas, din var inte riktigt vad jag var ute efter , du kollade bara om det var ett udda eller jämnt tal.
det jag ville var att kolla 2 potenser... tex 1 , 2 ,4 ,8 , 16, 32 , 64, 128 , 256 , 512 osv

//Roger


Svara

Sv: veckans nöt #2

Postades av 2004-11-03 10:04:55 - Martin Adrian

public bool IsEven(int tal)
{
    return (((tal >> 32) & 1 ) == 0);
}


konstig funktion. Vad den gör är att den kollar om bit 33 är 0.

Ett tal är ju jämt om den mista biten är 0. dvs (tal & 1) == 0


Svara

Sv: veckans nöt #2

Postades av 2004-11-03 10:08:11 - Roger Alsing

Jag tror Martin vinner...

min lösning var :

bool powerof2(int number) 
{ 
	double power=Math.Log (number,2);
	return power == (int)power;
}	


där jag kollade om exponenten är ett heltal..
men att and'a och inte blanda in flyttal är ju helt klart snyggare :)

//Roger


Svara

Sv: veckans nöt #2

Postades av 2004-11-03 11:13:29 - Andreas Håkansson

Martin,

<b>konstig funktion. Vad den gör är att den kollar om bit 33 är 0.
Ett tal är ju jämt om den mista biten är 0. dvs (tal & 1) == 0</b>

JapP! Du skall helt enkelt glömma bort min kod. Jag satt och tänkte på att kolla den sista
biten (tvåkomplement) men det är juh om talet är negativt eller positivt. Sen gjorde jag juh
fel - men jag var som sagt inte speciellt vaken ;)


Svara

Sv: veckans nöt #2

Postades av 2004-11-03 11:19:22 - Roger Alsing

Andreas din kod kan optimeras till:

return tal<0;


;) *retas*

//Roger


Svara

Nyligen

  • 08:28 Butiksskyltar: Hur upplever utbude
  • 22:31 Slappna av
  • 19:55 kick-off med fokus på hälsa?
  • 19:53 kick-off med fokus på hälsa?
  • 16:24 Föreslå en skönhetsklinik online
  • 16:23 Föreslå en skönhetsklinik online
  • 18:42 Hvor finder man håndlavede lamper
  • 18:41 Hvor finder man håndlavede lamper

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 570 786
27 960
271 761
720
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies