C# ile asal çarpanları bulan kodlar nasıl yazılır ?

bluehacc

Üye
2 Tem 2015
96
4
C# öğrenmeye başladım ama henüz algoritma ve veri yapılarını öğreniyorum do while döngüsünü öğrendikten sonra girilen sayının asal çarpanlarını ekrana yazan bir kod yazmak istedim fakat sadece en küçük asal çarpanı buluyor. Nerde yanlış yaptığımı söyler misiniz ?
szfie2e.png
 

By Birkan

Junior Hunter
18 Nis 2022
629
3
700
C#:
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApplication47
{
    class Program
    {
        static void Main(string[] args)
        {
            ArrayList ar = new ArrayList();
            int sayac = 0,carp=1,carp2=1;
            for (int i = 2; i <= 1000; i++)
            {
                for (int J = 1; J <= i; J++)
                {
                    if (i % J == 0)
                    {
                        sayac++;
                    }
                }
                if (sayac == 2)
                {
                    ar.Add(i);

                }
                sayac = 0;
            }
            int xx = 0,yy=0,k=1;
            Console.Write("Sayı giriniz: ");
            int x = Convert.ToInt32(Console.ReadLine());
          

            foreach (var item in ar)
            
            {
                
                for (;;)
                {
                    
                    if (x % (int)item == 0)
                    {
                        Console.WriteLine(item);
                        carp *= (int)item;
                        xx = x / (int)item;
                        x = xx;
                    }

                
                    else
                    {
                        break;
                    }

                  


                }
              

            }

            

        }
    }
}
 

ZuL-RaA

Kadim Üye
9 Ara 2017
5,550
16
837
Semerkant
Merhabalar,

Asal çarpanları bulabilmek için program olsaydı RSA şifrelemesi olmazdı. Daha doğrusu çoğu şifreleme şu an olmazdı.

Tek fonksiyonlardan çarpma fonksiyonu kullanması kolay çözmesi zor bir fonksiyondur. Küçük sayılarda belki mümkün olabilir ama büyük sayılarda çok mümkün değil.

2 * 3 * 5 * 7 * 19 * 91 = 363090

Sırayla asalları bölmeyi deneyip sonuç verip vermediğine bakabilirsiniz ama dediğim gibi küçük sayılarda çalışır.
 

bluehacc

Üye
2 Tem 2015
96
4
Benim gördüğüm şey hataya belki sebebiyet vermez lakin bir sayı giriniz: dan sonra boşluk bırakman gerekiyor
Yok hocam onun ekrana yazılmasıyla ilgili bir hata yok

Merhabalar,

Asal çarpanları bulabilmek için program olsaydı RSA şifrelemesi olmazdı. Daha doğrusu çoğu şifreleme şu an olmazdı.

Tek fonksiyonlardan çarpma fonksiyonu kullanması kolay çözmesi zor bir fonksiyondur. Küçük sayılarda belki mümkün olabilir ama büyük sayılarda çok mümkün değil.

2 * 3 * 5 * 7 * 19 * 91 = 363090

Sırayla asalları bölmeyi deneyip sonuç verip vermediğine bakabilirsiniz ama dediğim gibi küçük sayılarda çalışır.
aslında ben kendi yazdığım kodlarla ilgili bir düzeltme istedim. Yani yazdığım kodlar problemin mantığına uygun çalışıyor. a < sayı olduğu sürece döngüyü tekrarlamasını istiyorum ama olmuyor

C#:
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApplication47
{
    class Program
    {
        static void Main(string[] args)
        {
            ArrayList ar = new ArrayList();
            int sayac = 0,carp=1,carp2=1;
            for (int i = 2; i <= 1000; i++)
            {
                for (int J = 1; J <= i; J++)
                {
                    if (i % J == 0)
                    {
                        sayac++;
                    }
                }
                if (sayac == 2)
                {
                    ar.Add(i);

                }
                sayac = 0;
            }
            int xx = 0,yy=0,k=1;
            Console.Write("Sayı giriniz: ");
            int x = Convert.ToInt32(Console.ReadLine());
         

            foreach (var item in ar)
           
            {
               
                for (;;)
                {
                   
                    if (x % (int)item == 0)
                    {
                        Console.WriteLine(item);
                        carp *= (int)item;
                        xx = x / (int)item;
                        x = xx;
                    }

               
                    else
                    {
                        break;
                    }

                 


                }
             

            }

           

        }
    }
}
Hocam siz direkt kodları yazmışsınız. Ben kendi yazdığım kodlarla alakalı düzeltme istedim çünkü yazdığım kodlar problemin mantığına uygun çalışıyor. a < sayı olduğu sürece döngüyü tekrarlamasını istiyorum ama olmuyor sadece bir kez çalışıyor

C#:
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApplication47
{
    class Program
    {
        static void Main(string[] args)
        {
            ArrayList ar = new ArrayList();
            int sayac = 0,carp=1,carp2=1;
            for (int i = 2; i <= 1000; i++)
            {
                for (int J = 1; J <= i; J++)
                {
                    if (i % J == 0)
                    {
                        sayac++;
                    }
                }
                if (sayac == 2)
                {
                    ar.Add(i);

                }
                sayac = 0;
            }
            int xx = 0,yy=0,k=1;
            Console.Write("Sayı giriniz: ");
            int x = Convert.ToInt32(Console.ReadLine());
         

            foreach (var item in ar)
           
            {
               
                for (;;)
                {
                   
                    if (x % (int)item == 0)
                    {
                        Console.WriteLine(item);
                        carp *= (int)item;
                        xx = x / (int)item;
                        x = xx;
                    }

               
                    else
                    {
                        break;
                    }

                 


                }
             

            }

           

        }
    }
}
Yazdığım kodlarda şöyle bir mantık hatası olabilir. girilen sayıyı 2den başlayıp bir bir artan sayılara bölüyor. doğrusu 2den başlayıp en küçük asal sayılara bölmeye devam etmesi gerekirdi. Bunun içinde asal sayıları bulan bir kod yazmıştım a değişkenini datayı o kodlardan çekecek şekilde ayarlamam lazım ki o kadar yazılım bilgim yok
 
Üst

Turkhackteam.org internet sitesi 5651 sayılı kanun’un 2. maddesinin 1. fıkrasının m) bendi ile aynı kanunun 5. maddesi kapsamında "Yer Sağlayıcı" konumundadır. İçerikler ön onay olmaksızın tamamen kullanıcılar tarafından oluşturulmaktadır. Turkhackteam.org; Yer sağlayıcı olarak, kullanıcılar tarafından oluşturulan içeriği ya da hukuka aykırı paylaşımı kontrol etmekle ya da araştırmakla yükümlü değildir. Türkhackteam saldırı timleri Türk sitelerine hiçbir zararlı faaliyette bulunmaz. Türkhackteam üyelerinin yaptığı bireysel hack faaliyetlerinden Türkhackteam sorumlu değildir. Sitelerinize Türkhackteam ismi kullanılarak hack faaliyetinde bulunulursa, site-sunucu erişim loglarından bu faaliyeti gerçekleştiren ip adresini tespit edip diğer kanıtlarla birlikte savcılığa suç duyurusunda bulununuz.