Kullanıcı tarafından belirlenen dersler ve haftalık saatlerine göre yine kullanıcı tarafından girilen öğrencinin ders notlarından ağırlıklı ortalamanın bulunması ve öğrencinin teşekkür, takdir belgesi alıp almadığının tespit edilmesi.
Kodumuz
Öncelikle Main metodunu açıklayalım. Main metodu burada 35. satırda başlıyor ve programımız çalışmaya başladığında ilk olarak çalışacak metoddur. Diğer motodlar, Main içerisinde çağrılır.
Koşul sağlandığı sürece (yani bu örnekte kullanıcının devam edip etmeme isteğine göre) bu işlemin yapılmasını istediğimiz için kodlarımızı do-while döngüsü içerisine yazıyoruz. while() parantezindeki kodun, koşulu sağlayıp sağlamamasına göre do içerisindeki kod tekrar çalışıp çalışmayabilir.
İsteyeceğimiz not ve ders saatleri de yine kullanıcıya bağlıdır. Kulanıcının gireceği değerlere göre değişiklik göstereceğinden öndelikle for döngüsü dışında kaç adet ders bilgilerinin girileceğini öğrenmek amacıyla ders sayısı kullanıcıdan alınır.
Alınan ders sayısı adedince yeni ders bilgileri girileceğinden ve biz bunu bilmediğimizden dolayı i değerli bir integer dizisi oluşturulur.
Burada i, her bir dersi temsil eder. Örneğin, 3 adet ders bilgisi girlecekse, dizi indexi 0 dan başladığı için i = 2 dir.
Oluşturulan bu dizi 2 boyutludur bunun sebebi ise her bir ders için yani her bir ders[i,] için, ilgili dersin dersin saat ve not bilgisi tutulur. ders[i,0] da, dersin saat bilgisi tutulurken, ders[i,1] de, dersin not bilgisi tutulmaktadır.
Girilen ders sayısında saat ve not bilgisi sırayla dizilere depolandıktan sonra buradaki not ve saat bilgisi ortHesapla isimli bizim yazdığımız fonksiyona gönderilir. (7. satırda)
ortHesapla fonsiyonunun parametresi int[,] dersler dir. Ayrıca değerler sonucunda bir ortalama hesaplayıp bunu döndüreceği için void değildir. double değer döndürür, return kullanılır.
ortHesapla içerisinde yine for döngüsü kullanılarak her i için (yani her ders için) olan saat ve not bilgileri toplanır. Sonuçta toplam bir saat değeri ve not değeri olmuş olur.
Buradaki for döngüsü dersler isimli integer dizinin ilk elamanının uzunluğu kadar yani i nin uzunluğu kadar döner.
Normalde uzunluğa erişmek için .Length kullanılırken dizilerin herhnagi bir elemanı sayısınca uzunluğa ulaşmak için .GetLength() kullanılır. GetLength parametre alır. Örneğin, burada dizi i (yani ders adedi) uzunluğunda dönmesi için int[i,] ders dizisini ilk elemanı olan i nin index i kullanılır. Bu da 0 dır. Bu nedenle bu programda .GetLength(0) şeklinde kullanılmıştır.
Not/saat return ile döndürülerek bir ortalama oluşturmuş olur.
Main içerisinde ortHesapla() fonksiyonu çağrılarak onun döndürdüğü değer ort değişkenine atanır.
Bir alt satırda ise bu ort değişkenini parametre olarak alan bir belgeYazdir() fonksiyonu çağrılmıştır.
belgeYazdir fonksiyonu (19. satırda) içerisinde Console.WriteLine() ile ekrana yazı yazdırır. Bu nedenle değer döndürmez, void dir. İçerisindeki if ve else ler ile, hesaplanan ortalam değerinin hangi belgeye eşdeğer olduğunu bulur ve bunu Main metodunda çağırıldığı zaman ekrana yazdırır.
Devam etmek istendiğinde aynı işlemler devam eder.
Kodun Çıktısı
Devam etmek istendiğinde bu şekilde devam ediyor.
Kaynak Kodu (Source Code)
using System;
namespace DenemeBirKi
{
class Program
{
static double ortHesapla(int[,] dersler)
{
double toplamSaat=0, toplamNot=0;
for(int i=0; i<dersler.GetLength(0); i++)
{
toplamSaat += dersler[i, 0];
toplamNot += dersler[i, 0] * dersler[i, 1];
}
return toplamNot / toplamSaat;
}
static void belgeYazdir(double ort)
{
if(ort >= 85)
{
Console.WriteLine("{0} ortlamanız ile Taktir Belgesi aldınız.", ort);
}
else if(ort >= 75)
{
Console.WriteLine("{0} ortlamanız ile Teşekkür Belgesi aldınız.", ort);
}
else
{
Console.WriteLine("{0} ortlamanız belge almaya yetmedi.", ort);
}
}
static void Main(string[] args)
{
int dersSayisi;
char devam;
double ort;
do
{
Console.Write("Ders sayısı:");
dersSayisi = Convert.ToInt32(Console.ReadLine());
int[,] ders = new int[dersSayisi, 2];
for(int i = 0; i < dersSayisi; i++)
{
Console.Write("{0}. dersin haftalık saati:", i + 1);
ders[i, 0] = Convert.ToInt32(Console.ReadLine());
Console.Write("{0}. dersin puanı:", i + 1);
ders[i, 1] = Convert.ToInt32(Console.ReadLine());
}
ort = ortHesapla(ders);
belgeYazdir(ort);
Console.Write("Devam etmek istiyor musunuz? (e/h)");
devam = Convert.ToChar(Console.ReadLine());
} while (devam == 'e' || devam == 'E');
}
}
}
Kaynaklar
Örneklerle Algoritma ve C# Programlama – Erhan Arı
Bu yıl öğrendim ki algoritma = her şey. Bu mantığı iyice kavramak için pek çok algoritma örneği üzerinde çalışmak istiyorum. Bu yüzden böyle bir seriye başlamaya karar verdim. Umarım her şey planladığımdan da güzel olur ve geriye döndüğümde bu sayfaları, zihnimde ardından gelecekleri bilme hissiyle okurum.
Detaylar
Klavyeden girilen bir metnin karakterlerini sırasıyla büyüten program
Kodumuz
iç içe iki for kullanarak her bir aşamada o aşamanın sayısı olan harf büyük harfe çevrilecek. Örneğin Coldplay kelimesi için yapılan aşamalara bakalım.
Öncelikle kullanıcıdan alınan kelimenin herhangi bir harfinin büyük olma olasılığı nedeniyle, her bir harfi .ToLower() ile küçük hale getirilir.
Ardından ilk for içinde 0. indis için yani ilk satır için içindeki for döngüsüne girilir ve içerdeki döngünün 0. indisi yani ilk harfi, i==j olduğu için büyütülür.
Söz konusu harf yani kelime[j] char olduğu için önce .ToString() ile string hale getirilir ardından .ToUpper() ile büyütülür.
i si j ye eşit olmayan yani i != j kelimeler için direkt olarak stringe dönüştürme işlemi yapılarak yazdırılır.
İçteki for döngüsünden çıktıktan sonra Console.WriteLine() yazmamızın sebebi yeni kelimeyi yazmak için bir alt satıra geçmesi.
i=0 için dönen for döngüsü şimdi i=1 için dönecektir. ilk satırımıza 0 dersek ikinci satırımızın numarası 1 olacaktır ve 2. satırda da kelimenin 2. harfi büyütülmelidir. Burada if içinde i==j kontrolü yapmamızın sebebi daha açıklayıcı olmuştur.
Dıştaki döngü kelimelerin sırasını, satırını temsil ederken içteki döngü kelimenin harflerinin sayısını temsil eder.
Kodun Çıktısı
Kodumuz *Bonus
Burada, bir önceki kodumuzda 30. satırda olan Console.WriteLine() silinmiştir. Üstteki kodumuzdan farklı olarak 18. ve 19. satırda kodlar eklenmiştir.
Bir önceki kodun çıktısı, her bir satırda sırayla bir harfin büyütülmesi şeklinde görünürken buradaki kod çalıştığında her defasında ekran temizlenerek metin tekrar ekrana yazdırılıyor. Metin harf harf ekrana yazdırılırken sırası gelen harf büyük harfe çevrilerek yazdırılıyor.
Her adımda kodun bekletilmesi gerekir. Aksi halde program derlenir derlenmez işlem bitirilir. Programın çalışıp çalışmadığını anlayamayız.
Programın çalışıp çalışmadığını görmek için burada programo 500ms bekletiyoruz. Bu işlemi Thread sınıfından Sleep() metoduyla yapıyoruz.
Thead sınıfını kullanabilmek için en üste (bkz. 2. satır) System.Threading kütüphanesi eklenmelidir.
Hatalar
İlk hatamız 21. ve 25. satırda Console sınıfından WriteLine() metodunu kullanmamız. Burada WriteLine her bir harfi tek bir satıra basıp alt satıra geçecektir. Kelimeyi bir bütün halindee görebilmemiz için Write() metodunu kullanmamız gereklidir.
İkinci hatamız if koşulu içerisinde kelime[j] yani bir char değerinin j yani bir int değerine eşit olup olmamasını kontrol etmeye çalışmamızdır. Burada her satırda o satırın index sayısına eşit olan harf büyütüleceği için i = j koşulunu yazmamız gerekir.
Hatalı ilk kodumuzun çıktısı.
Bir üstteki hatamızı düzeltip WriteLine() yerine Write() yazıyoruz fakat kodumuz hala istediğimiz çıktıyı vermeyecektir.
Her harfin yeni bir sayırda yazılmasını engellemiş olduk fakat bu seferde kelimenin harfi sayısınca, aynı kelime peş peşe tek bir satırda yazılacaktır.
Bunu düzeltmek için ilk for un içine, içteki for un dışına Console.WriteLine(); yazmamız gerekecektir. Bu sayede içteki for da bir kelime yazımı tamamlandığı zaman bir boşluk bırakarak yeni bir satıra geçilecektir. Döngünün ikinci aşamasına başlanacaktır.
Ayrıca üstteki if koşulu hatamız aynı şekilde devam ediyor. Her satırda o satırın index sayısına eşit olan harf büyütüleceği için if parantezleri içerisine i = j koşulunu yazmamız gerekir.
Hatalı ikinci kodumuzun çıktısı.
Kaynak Kodu (Source Code)
using System;
namespace DenemeBirKi
{
class Program
{
static void Main(string[] args)
{
string kelime;
Console.WriteLine("Bir sözcük giriniz.");
kelime = Console.ReadLine().ToLower();
for(int i = 0; i < kelime.Length; i++)
{
for(int j = 0; j < kelime.Length; j++)
{
if(i==j)
{
Console.Write(kelime[j].ToString().ToUpper());
}
else
{
Console.Write(kelime[j].ToString());
}
}
Console.WriteLine();
}
}
}
}
Kaynaklar
Örneklerle Algoritma ve C# Programlama – Erhan Arı
Basit bir tasarruf uygulaması kodu üzerinden typecast (bilinçli dönüşüm) kullanımını inceleyeceğiz. Kodun detaylarında saatte 2 tl elektrik yakan bir ampul ile totalde %20 tasarruf sağlayan bir ampulün girilen kullanma süresi gibi detaylar ile birlikte faturaya yansıyacak fiyatlarını yazdıran bir kod yazmamız isteniyor.
Kodumuz
16. satırda yapılan typecast (bilinçli dönüşüm) işlemi (float) 80 / 100 şeklinde olmalı.
17. satırda Console.WriteLine() metodu ile ekrana yazdıracağımız şeyleri yazdırırken dikkat etmemiz gerekenler vardır. Eğer bir metin yazdırmak istiyorsak bunları parantezde tırnak işaretleri içerisinde yazarız. Eğer ki yazdırmak istediğimiz şeyler kodun içinde tanımlamış olduğumuz değişkenler ise, bunları parantezde direkt olarak değişkenin ismini yazmak suretiyle yazdırabiliriz fakat eğer hem metin hem de değişken yazdırmak istiyorsak bunları + (artı) işareti ile aynı anda yazdırabiliriz. C dilindeki printf fonksiyonunun parantez içindeki gibi virgül ile ayırmak söz konusu değildir.
Kodun Çıktısı
Hatalar
Bu hatalı kodda, 16. satırdaki bölme işlemi parantez içinde yapılmış ve önünde de typecast kullanılmak istenmiş fakat bölme işleminin sonucu 0.8 olduğu için işlem yapıldıktan sonra float türüne dönüştürmek bir şey ifade etmeyecektir. Çünkü işlemin sonucu olarak sadece virgülden/noktadan öncesini alacaktır ve 0.8’nın 0’ını alarak floata dönüştürdükten sonra 0.0 elde edilmiş olur.
Hatalı ilk kodumuzun çıktısı budur.
Bu hatalı kodun çıktısında görüldüğü gibi sonuç 0 olur çünkü 50 * 0.0 = 0
Buradaki hatalı kodda ise, 16. satırda float ifadesi paranteze alınmalıdır. Aksi taktirde bu ifade tanımlanamayacaktır.
Type Conversion (tür dönüşümü)’ın bir alt formu olan Typecast konusu anladığım kadarıyla; basit, temel ve bir o kadar da önemli bir konu. Kodlamaya başladığım ilk zamanlarda öğrenmiş olmama rağmen ve hatta şu kısa süreli blog serüvenimde bile bununla ilgili bir örnek yapmış olmama rağmen, yaptığım matematik işlemlerinde bu konuyla ilgili detaylar yüzünden sonuca ulaşamadığımı fark ettiğim bir konu olduğu için tür dönüşümleri için ayrı bir başlık açmak istedim.
Veri türeleri arası dönüşüm, bir değişkenin değişik türdeki hâlinin başka bir değişkene atanmasıdır. Typecast (type casting) de denir. İki formu vardır.
Typecast
Bilinçsiz Dönüşüm (Implicit Type Conversion): Düşük kapasiteli bir değişken, sabit ya da değişken ve sabitlerden oluşan matematiksel ifadenin daha yüksek kapasiteli bir değişkene atanması. Özel bir kod gerekmez
Bilinçli Dönüşüm (Explicit Type Conversion): Genellikle derleyicinin izin vermediği durumlarda kullanılır. Bilinçli tür dönüşümüyle küçük türün büyük türe dönüştürülmesi gereksizdir, bilinçsiz tür dönüşümü bu işi yapar. Dönüşümü yapılan değişkenin tuttuğu değer, dönüştürülecek türün kapasitesinden büyükse veri kaybı gerçekleşebilir.
Bilinçsiz Dönüşüm (Implicit Type Conversion)
Bilinçli Dönüşüm (Explicit Type Conversion)
object Türüyle İlgili Kurallar
object türündeki bir değişkene başka herhangi bir türdeki değişken ya da sabit (string dışında) + işaretiyle eklenemez.
object türündeki bir değişkene herhangi bir türdeki değişken ya da sabit atanabilir (bilinçsiz tür dönüşümü). object türündeki bir değişkeni başka bir türe çevirmek için tür dönüştürme işlemi kullanılır. Dönüştürülen türlerin uyumlu olması gerekir.
Aynı satırda çifte dönüşüm yapılamaz.
string Türüyle İlgili Dönüşümler
x.ToString(): x değişken ya da sabitini stringe çevirip tutar.
string türüyle ilgili bilinmesi gerekenler:
Methods (System.Convert sınıfı)
Tür dönüşümü için metotlar System isim uzayında Convert sınıfındadır. Hemen hemen her tür her türe dönüştürülebilir. Değişken türlerinin CTS (Common Type System) karşılıkları bilinmelidir.
Merhaba, bugün bahsedeceğim örnek kod, konularına tam anlamıyla hakim olduğum bir kod değil fakat bazı araştırmalar ve okumalar yaparak belli bir yere kadar ilerleme kaydettim ve bu kodu yazabildim. Bir sıkıntımız daha var ki, bu kodu yazmayı ve araştırmalarımı 8 Aralık 2019 Pazar günü tamamlamama rağmen yazısını bugün yani 26 Ocak 2020 Pazar günü yazabiliyorum. Açıkçası kodun ayrıntılarını maalesef unutmuşum. Şimdi sizlere anladığım ve hatırladığım kadarını aktarmaya çalışacağım.
Challenge Türü: Easy
Detaylar
Kodumuz
2. satırda System.Linq kütüphanesi kullanılmalı. Kullanılmazsa 13. satırdaki, dizi elemanlarının büyükten küçüğe doğru sıralanması için kullandığımız OrderByDescending kodu çalışmaz. LINQ sorgusu hafızadaki (veya bir veri kaynağındaki) veri kümesinden program içinde SQL gibi sorgulama yaparak, seçilen verilerden oluşan yeni bir liste elde etmemizi sağlar. Linq hakkında daha fazla detay için bakabilirdiniz -> http://yazilim.cevapsitesi.com/Makaleler/5/linq-language-integrated-query-dile-entegre-edilmis-sorgu-nedir
9. satırda kullandığım ayrac dizisini, yani bölmek istediğim cümledeki sözcükleri birbirinden ayıracak olan sembolleri ve boşluklarları tek tek kendim yazmak durumundayım. Buna maalesef alternatif bir çözüm bulamadım. Sıkıntı şu ki, benim orada tüm karakterleri yazmam mümküd değil ve benim yazmadığım bir sembol ile karşılaşılırsa kelimeleri ayrıması mümkün olmayacak. Örneğin kod ekrandan merhaba%okuyucu şeklinde bir girdi alsın. Bu yadığım kodda % sembolü bir ayraç olarak ifade edilmediği için buradaki merhaba ve okuyucu kelimeleri seçilemeyecek. Bunun yerine merhaba%okuyucu yu tek bir kelime olarak alacak. Bu satırdaki kod hatalı değil fakat eksiktir.
10. satırda bir önceki yazımda da bahsettiğim .Split ifadesi yer alıyor. .Split() ifadesinde parantez içine yazdığımız şeyler bizim ayraçlarımız/bölücülerimiz oluyor. Kodumuz parantez içinde ne varsa, istenileni o ifadeyi gördüğü zamanlarda bölerek bir dizi haline getiriyor.
13. satırda OrderByDescerding kodu sayesinde dizimizin elemanlarını büyükten küçüğe sıralayabiliyoruz. (Bu arada büyükten küçüğe, uzundan kısaya için Descending; küçükten büyüğe, kısadan uzuna için Ascending kullanılır.)
Kodun Çıktısı
Hatalar
Hatalı kodda 10. satır, ana kodda 13. satırda olan First() ifadesinin neden yazıldığına tam olarak hakim değilim fakat ortadan kaldırdığımızda aşağıdaki gibi bir hata veriyor. Anladığım kadarıyla En büyükten en küçüğe(en uzundan en kısaya) doğru sıraladığımız sözcük dizimizde tek bir elemanı seçip döndürmemiz geremiyor, bu da en uzun sözcük olan dizinin ilk eleman olduğu için First() ifadesi kullanılıyor. (asaba Last() gibi (dizinin son elemanı) ifadeler de var mı, kullanılıyor mu?)
string.Split yöntemi, veri tabanında belirli işaretlere göre tek bir alanda tutmak istediğimiz kayıtları, bir veya daha fazla sınırlayıcı temelinde bölerek bir alt dizeler dizisi oluşturur. Genellikle bir dizeyi sözcük sınırlarında ayırmanın en kolay yoluymuş. Ayrıca, diğer belirli karakter veya dizelerde dizeleri ayırmak için de kullanılıyormuş
Split metodunun temel çalışma şekli şöyledir. Bir dizgeyi (karakter dizisi) belirli bir ayraç ile parçalayıp, parçalardan bir dizi döndürür.
Kullanım 1: C# string nesneleri ile kullanılır. Aşırı yüklenmiş bir metottur fakat en sık kullanım şekli ayırıcı olarak bir karakter(char) girilmesi ile yapılır.
Kullanım 1.1Kullanım 1.2Kullanım 1 Çıktısı
Kullanım 2: C# split metodunun aşırı yüklenmiş bir metot olduğunu yazmıştım. Karakterlerden oluşan bir dizi ile birden fazla karakter ile de parçalamak mümkündür.
Örnek: 2019/12/07 18:06 şeklindeki tarihi parçalara ayırma
Kullanım 2Kullanım 2 Çıktısı
Hatalar
Saati 18.06 şeklinde yazdığım ve ayrac dizisine . (nokta) elemanını eklemediğim için kodu yazdıramadım. Hata verdi. Aslında kod yazmayı bitirip derlendiğinde bir hata görünüyor fakat çalıştırmak istediğimizde özel bir hata oluşuyor. Syntax hatası olmamamsı kodun doğru olduğunu göstermez. Bu özel hata ile ilgili daha fazla detay isterseniz şu linkteki yazıyı inceleyebilirsiniz: https://docs.microsoft.com/tr-tr/dotnet/api/system.indexoutofrangeexception?view=netframework-4.8
10. satırda tanımladığımız result değişkeni for döngüsünün dışında tanımlanmalı (örn. 7. satırda) çünkü for döngüsünün amacı bu değeri her seferinde yeni elde ettiğimiz değeriyle değiştirerek i ile çarpmak. (Sistem, [result*i=result] 1*1=1 1*2=2 2*3=6 6*4=24 şeklinde işliyor)
Aynı zamanda bu tanımlanacak result değişkenine bir ilk değer ataması yapılmalı yoksa null değeri döndürür (bildiğim kadarıyla?) ve bu atanacak ilk değer 1 olmalı ki çarpım işlemi yapıldığında ilk olarak kendisini versin. Örneğin 0 değeri atanırsa bu result değişkeni sürekli 0 değeri olarak kalır çünkü 0 ile çarpılan her sayı yine 0 değerini verir.
12. satırda kendi yaptığım bir hatayı koyuyorum. Hızlı bir şekilde yazarken i yerine 1 yazmıştım. Fakat for döngüsünün içerisinde i‘ yi tanımlamamızın sebebi onu döngüyü çevirmesi amacıyla kullanmak zaten. i yerine 1 yazdığımız zaman result değerini sürekli olarak 1 ile çarpmış ve hep aynı sonucu elde etmiş oluruz. Burada result değişkeninin değeri 1 olduğu için sonuç her zaman result*1=1 olur.
15. satırda num değil de result değişkenini yazmalıyız çünkü biz FirstFactorial metodunda result değişkenini döndürüyoruz ve Main metoduna bu değişkeni yolluyoruz. num ise bizim parametremizdir. Yani Main metodundan aldığımız değişken.
20. satırda, kullanıcıdan aldığımız değeri C# dilini kullanarak yazdığımız kodda ve Main metodundan aldığımız için string türünde alıyoruz ve bunu FirstFactorial metoduna yollarken, işlem yaptırmak için vs. integer türünde yolluyoruz. Bunun için de Convert.ToInt32 gibi bir dönüştürücü kullanmamız gerekir.
Wow – Code Worth Checking | Come Look Here
Coderbyte platformunda bu kodu yazarken faktöriyel kodlarını inceliyordum ve bir kullanıcının yazdığı şu koda denk geldim. Aslında inceleyince gayet basit bir mantıkla yazılmış ve daha kısa, pratik görünüyor. İncelemeye, öğrenmeye değer bir kod olduğunu düşünüyorum. Ufku genişletmek için farklı bir bakış açısı olur en azından.
Bugün “Challenges | … ” başlıklı bir seriye başlamayı düşünüyorum. Coderbyte isimli kodlama değerlendirme platformundaki meydan okumalar bu seride olacak. C# öğrendiğim için istenilen kodları C# dilinde yazacağım. Yeni diller öğrendikçe bu diller değişebilir. Bu serinin ilk uygulaması “First Reverse” isimli challenge. Bu cahllenge’ın temel mantığı dizi elemanlarını / ekrandan girilen değişkenleri ters sıra ile yazdırma. ASlında daha önceki yazımda olan bir kod fakat buna rağmen kodu yazaken zorluk çektim. Hala öğrenememişim…
Challenge Türü: Easy
Detaylar
Kodumuz
9. satırda reverse değişkenine bir ilk atama yapmayı unuymamalıyız. ( Burada string a = String.Empty; , string a = Null; veya string a = “”; kullanabiliriz.
11. satırda for föngüsünün içerisini mutlaka (int i = str.Length – 1; i >= 0; i–) şeklinde yazmalıyız. (int i = str.Length; i > 0; i–) veya (int i = 0; i <= str.Length -1; i++) şeklinde yazmamız yanlış olur.
13. satırda a değikenine i yi ekleyip devam etmek değil de i nin dizi içerisinde ifade ettiği değişkenin değerini ekleyip atamayı unutmamalıyız. (yani a += i; yazmamalıyız.) Ayrıca a = str[i]; gibi bir hata da yapmamalıyız.
Kodun Çıktısı
Hatalar
11. satırda döngüyü döndürmeye sağlayacak olan int i değişkenine 0 değerini verip artırarak ilerlemek istiyor olabiliriz fakat bunu yaparken int i değişkeni ile string reverse değişkenlerini kıyaslayamayız. Türleri eşit olmalı. for (int i = 0; i <= str.Length -1; i++) veya for ( int i = str.Length -1; i >= 0; i–) yazabiliriz.
11. satırdaveya mutlaka for ( int i = str.Length -1; i >= 0; i–) şeklinde yazmalıyız. for (int i = 0; i <= str.Length -1; i++) şeklinde yazdığımızda kodun çıktısı yukarıdaki gibi olur. İçindeki harfleri ters çevirip yeni bir dizi oluşturmasını istediğimiz diziyi ters çevirmez. Ayrıca for (int i = 0; i < str.Length; i++) şeklinde de yazmamalıyız. Bu şekilde de hata veriyor (idk why?).
13. satırda for döngüsünün içinde i‘ nin değerini direkt olarak reverse isimi string değişkene ekleyemeyiz çünkü burada i değişkeni bizim değişkenimizin değerini etkilemek / değiştirmek için kullanılmıyor. i değişkeninin kullanılma amacı reverse isimli string değişkenini bir diziye dönüştürüp bu dizinin her bir elemanının sırasını temsil etmektir. bu sayede i. eleman şudur i+1. eleman şudur gibi dizinin elemanlarını tersten yazdırmamız mümkün olacaktır.