Umut D.

Umut D.

Powered by Jekyll & Github

  • Programlar

  • fkp-hesaplayici

    Geçtiğimiz hafta, çalıştığım işle ilgili bir görevde, kombinasyon oluşturmam ve öncelikle bunun sayısını belirlemem gerekti. Haliyle elime kalem kağıdı alıp kombinasyon hesabı yapmaya üşendim. Ancak program yazmaya nedense üşenmedim. Kombinasyon hesaplayabilen bu programı yazdıkça ne olur ne olmaz diye yanına faktöriyel ve permütasyon hesaplama seçeneklerini de koydum ki, belki böyle proje, ödev hazırlamak isteyenlere veyahut netten metotlar yardımıyla işlem yapan bir program arayanlara yardımcı olayım dedim.

    Aslında günlük hayatta faktöriyel, kombinasyon, permütasyon hesaplarını işletim sistemlerindeki hesap makinelerinden tutun Excel’e kadar pek çok program kolaylıkla yapmakta. Ben sadece bunu C#’a taşımak ve temiz bir şekilde yazmaya çalıştığım kodlarla bunu gerçekleştirmek istedim. İtiraf ediyorum, özel bir amacım yoktu ve tasarım konusunda sıfırım. Neyse, programın özelliklerine gelecek olursak;

    • Faktöriyel (maksimum 11),
    • Kombinasyon,
    • Permütasyon hesabı yapma.
    Faktöriyel, Kombinasyon, Permütasyon
    Hesaplayıcı
    Versiyon Durum
    Faktöriyel, Kombinasyon, Permütasyon
    Hesaplayıcı (Proje)
    Lisans Arşiv
    MD5: cce3c35143b205a011225df6fe52cba7 MD5: cce36559bc84b063a127d0f087b41e8c
    Boyut: 112 KB Boyut: 850 KB
    Gereksinimler: .Net Framework 4 Gereksinimler: .Net Framework 4
    Platform: Microsoft Windows Programlama Dili: C#
    İndir: Link İndir: Link

    Ek : Nasıl hesaplama yapıldığını görmeye gelenler için Hesapla.cs sınıfındaki kodlar:

    using System;
    
    namespace fkp_hesapla
    {
        public abstract class Matematik
        {
            private int _birinciSayi;
            private int _ikinciSayi;
            protected int Fark => BirinciSayi - IkinciSayi;
    
            public int BirinciSayi
            {
                get => _birinciSayi;
                set
                {
                    if (value < 12)
                        _birinciSayi = value;
                    else
                        throw new Exception("1. Sayı 11'den büyük olmamalı");
                }
            }
    
            public int IkinciSayi
            {
                get => _ikinciSayi;
                set
                {
                    if (value < 12 && _birinciSayi >= _ikinciSayi)
                        _ikinciSayi = value;
                    else
                        throw new Exception("2. Sayı 11'den büyük olmamalı.");
                }
            }
        }
    }
    
    namespace fkp_hesapla
    {
        public class Faktoriyel : Matematik
        {
            public int Hesapla(int birinciSayi)
            {
                BirinciSayi = birinciSayi;
    
                int sonuc = 1;
                for (int i = 1; i <= BirinciSayi; i++)
                    sonuc *= i;
    
                return sonuc;
            }
        }
    }
    
    namespace fkp_hesapla
    {
        public class Kombinasyon : Faktoriyel
        {
            public Kombinasyon(int birinciSayi, int ikinciSayi)
            {
                BirinciSayi = birinciSayi;
                IkinciSayi = ikinciSayi;
            }
    
            public int Hesapla()
            {
                return Hesapla(BirinciSayi) / (Hesapla(IkinciSayi) * Hesapla(Fark));
            }
        }
    }
    
    namespace fkp_hesapla
    {
        public class Permutasyon : Faktoriyel
        {
            public Permutasyon(int birinciSayi, int ikinciSayi)
            {
                BirinciSayi = birinciSayi;
                IkinciSayi = ikinciSayi;
            }
    
            public int Hesapla()
            {
                return Hesapla(BirinciSayi) / Hesapla(Fark);
            }
        }
    }