string[] kombinasyonParcalari = new string[] { "abc", "cba", "123", "456", "deneme" };
List<string> sonuclar=new List<string>();
for (int i = 1; i < Math.Pow(kombinasyonParcalari.Length, kombinasyonParcalari.Length); i++)
{
List<int> secilenler = new List<int>();
int k = i;
bool ayniParcaTekrarlandi=false;
while (k > 0)
{
int yeniParca = k % kombinasyonParcalari.Length;
if (secilenler.Contains(yeniParca))
{
ayniParcaTekrarlandi = true;
break;
}
secilenler.Add(yeniParca);
k = (k - yeniParca) / kombinasyonParcalari.Length;
}
if (!ayniParcaTekrarlandi)
{
string sonuc = "";
foreach (int parca in secilenler) sonuc += kombinasyonParcalari[parca];
sonuclar.Add(sonuc);
}
}
taban aritmetiği mantığıyla düşünürsek kolay.. Yani her kombinasyon parçası bir sayıyı ifade etsin, her kombinasyonumuz da o parçaların sıralamasını gösteren bir değer olsun.. Program kolay, visual studio da açıktı...
Kod:string[] kombinasyonparcalari = new string[] { "abc", "cba", "123", "456", "deneme" }; list<string> sonuclar=new list<string>(); for (int i = 1; i < math.pow(kombinasyonparcalari.length, kombinasyonparcalari.length); i++) { list<int> secilenler = new list<int>(); int k = i; bool ayniparcatekrarlandi=false; while (k > 0) { int yeniparca = k % kombinasyonparcalari.length; if (secilenler.contains(yeniparca)) { ayniparcatekrarlandi = true; break; } secilenler.add(yeniparca); k = (k - yeniparca) / kombinasyonparcalari.length; } if (!ayniparcatekrarlandi) { string sonuc = ""; foreach (int parca in secilenler) sonuc += kombinasyonparcalari[parca]; sonuclar.add(sonuc); } }
aynı parçanın birden fazla kez kullanılmasına izin vermiyoruz.. Kombinasyonparcalari istediğin miktarda olabilir. Sonuclar değişkenini de canının istediği gibi output edersin sonra..
Edit: Hatam var.. Ilk döngü 0'dan başlamalı, ama içindeki 'while' döngüsü 'do... While' döngüsüne dönüşmeli.. Neyse onu da sen halledersin. şu andaki haliyle sadece ilk kombinasyondan olan parça - benim örnekte "abc" listeye giremeyecek.
string[] kombinasyonParcalari = new string[] { "abc", "123", "$$$"};
List<string> sonuclar=new List<string>();
for (int i = 0; i < Math.Pow(kombinasyonParcalari.Length, kombinasyonParcalari.Length); i++)
{
List<int> secilenler = new List<int>();
int k = i;
do
{
int yeniParca = k % kombinasyonParcalari.Length;
if (secilenler.Contains(yeniParca)) break;
secilenler.Add(yeniParca);
k = (k - yeniParca) / kombinasyonParcalari.Length;
} while (k > 0);
if (k==0)
{
string sonuc = "";
foreach (int parca in secilenler) sonuc += kombinasyonParcalari[parca];
sonuclar.Add(sonuc);
if (!secilenler.Contains(0)) sonuclar.Add(sonuc+kombinasyonParcalari[0]);
}
}
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.