[MD-sorular] YNT: YNT: nxn kare simülasyon

Kadir GÜLEÇ kadir.gulec at spk.gov.tr
12 Tem 2009 Paz 18:05:49 EEST


ben de excel makrolarıyla sizden esinlenerek bir simülasyon yazdım
Bininci deneme sonunda benim sonuçlar da şöyle  (3-15):
 
0,379	 0,724	 0,749	 0,874	 0,934	 0,961	 0,977	 0,987	 0,99	 0,996	 0,996	 1	 0,999	

________________________________

Kimden: ozcan kasal [mailto:ozcankasal at yahoo.com]
Gönderilmiş: Paz 12.07.2009 16:48
Kime: Kadir GÜLEÇ; md-sorular at matematikdunyasi.org
Konu: Yan: YNT: [MD-sorular] nxn kare simülasyon




> Daha büyük boyutları da yapabilirsiniz
> bir satır çarpımının çift olduğunu bulmak için
> çarpma yapmaya gerek yok
> satır veya sütun içinde en az bir çift sayının
> geçmesi yeterli
> yani çarpım önemli değil
> önemli olan çarpıma giren tek tek elemanlar
> benim şu ara keyfim yok
> bir de sizin hazır algoritmanız var
> küçük bir iki değişiklikle
> daha büyük boyutlar için çalışır hale getirirsiniz
> kolay gelsin
> 
> Kadir Güleç


Haklısınız, kodu girerken beynim sulanmış. 15'e kadar test ettim. sonuçlar şöyle,

3 x 3 : 0.359664033597
4 x 4 : 0.703529647035
5 x 5 : 0.774822517748
6 x 6 : 0.89101089891
7 x 7 : 0.926807319268
8 x 8 : 0.962703729627
9 x 9 : 0.977102289771
10 x 10 : 0.987901209879
11 x 11 : 0.992300769923
12 x 12 : 0.997500249975
13 x 13 : 0.998700129987
14 x 14 : 0.999200079992
15 x 15 : 0.999400059994

kod şöyle

%%%%%%%%%%%%%%%%%%%%%%%%%%-Pyhton 2.6.1-%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

from __future__ import division

import random

def secim(n):
    s=[random.randint(1,n*n)]
    i=1
    while i<=n*n-1:
        s.append(0)
        i=i+1
     
    j=1
    while j<=n*n-1:
        k=0
        while k==0:
            r=random.randint(1,n*n)
            k=1
            for i in range(0,j):
                if r==s[i]:
                    k=0
            if k==1:
                s[j]=r       
        j=j+1


    return s


def cift(n):
    result=1
    m=secim(n)

    r=[1]
    c=[1]
    i=1
    j=1
    while i<=n-1:
        r.append(1)
        i=i+1
    while j<=n-1:
        c.append(1)
        j=j+1
    l=0
    p=0
    while l<=n-1:
        j=l*n
        while j<=(l+1)*n-1:
            if m[j]%2==0:
                r[l]=0
            j=j+1
        l=l+1

    while p<=n-1:
        j=p
        while j<=p+(n-1)*n:
            if m[j]%2==0:
                c[p]=0
            j=j+n
        p=p+1

    result=0
    i=0
    j=0
    while i<=n-1:
        if r[i]%2==1:
            result=1
        i=i+1
    while j<=n-1:
        if c[j]%2==1:
            result=1
        j=j+1
    return result



dim=15
number=10000



while dim<=15:
    deneme=0
    dogru=0
    while deneme <=number:
        k=cift(dim)
        if k==0:
            dogru=dogru+1
        deneme=deneme+1   
    print dim,"x",dim,":", dogru/deneme
    dim=dim+1

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%





      ___________________________________________________________________
Yahoo! Türkiye açıldı!  http://yahoo.com.tr <http://yahoo.com.tr/> 
İnternet üzerindeki en iyi içeriği Yahoo! Türkiye sizlere sunuyor!


-------------- sonraki bölüm --------------
Bir HTML eklentisi temizlendi...
URL: http://lists.math.bilgi.edu.tr/pipermail/md-sorular/attachments/20090712/3d97fe29/attachment.htm 


MD-sorular mesaj listesiyle ilgili daha fazla bilgi