Soru Toplam Puan Not

Benzer belgeler
Soru Toplam Puan Not

Doğu Akdeniz Üniversitesi Bilgisayar Mühendisliği Bölümü. BLGM 318 Ara Sınavı Đlkbahar Dönemi 13 Nisan Ad, Soyad Öğrenci No.

Bölüm 15. Fonksiyonel programlama dilleri (Functional Programming Languages)

Lambda İfadeleri (Lambda Expressions)

Maltepe Üniversitesi Bilgisayar Mühendisliği Bölümü BİL 203 Veri Yapıları ve Algoritmalar I

11- FONKSİYONLAR (FUNCTIONS)

SNU (Principles of Programming) Part I


Örnek: İki fonksiyondan oluşan bir program. Fonksiyon Tanımı

Bölüm 5. Adlar(Names), Bağlamalar(Binding s),tip Kontrolleri (Type Checking), ve Etki Alanları ( Scopes) ISBN

BBS 514 YAPISAL PROGRAMLAMA (STRUCTURED PROGRAMMING)

HB1002: ORACLE 10G VERĐTABANI PL/SQL ile PROGRAMLAMA (32 saat)

Bölüm 15. Fonksiyonel Programlama Dilleri ISBN

Bölüm 6. Diziler (arrays) Temel kavramlar Tek boyutlu diziler Çok boyutlu diziler

10/17/2007 Nesneye Yonelik Programlama 3.1

Metotlar. d e f metot_adı [ ( [ arg [= d e f a u l t ] ]... [, arg [, &expr ] ] ) ] deyim ( l e r ) end

Al Ruby'i Vur Python'a

1 PROGRAMLAMAYA GİRİŞ

YZM 2116 Veri Yapıları

BİL-142 Bilgisayar Programlama II

Semantik (Semantics): ifadelerin, deyimlerin, ve program birimlerinin anlamı Sentaks ve semantik bir dilin tanımı sağlar

Öğr. Gör. Musa AYDIN Fatih Sultan Mehmet Vakıf Üniversitesi

Yrd. Doç. Dr. Caner ÖZCAN

/ C Bilgisayar Programlama Final Sınavı Test Soruları. Adı soyadı :... Öğrenci no :... İmza :... Tarih, Süre : , 60 dak.

Yrd. Doç. Dr. Caner ÖZCAN

1 JAVASCRIPT NEDİR? 1

Pros and Cons of Pointers. Pointers. Avantajlar. Dezavantajlar

Örnek 4: Örnek Özyinelemeli fonksiyon örneği Bölüm 9. C++ programlama dilinde Nesne ve sınıf

İsimler ve Kapsam. 24 Şubat Programlama Dilleri - Pamukkale Üniversitesi 1

JAVA PROGRAMLAMA DİLİ ÖZELLİKLERİ

FONKSİYONLAR. Gerçek hayattaki problemlerin çözümü için geliştirilen programlar çok büyük boyutlardadır.

Çoktan Seçmeli Değerlendirme Soruları Akış Şemaları İle Algoritma Geliştirme Örnekleri Giriş 39 1.Gündelik Hayattan Algoritma Örnekleri 39 2.Say

WEEK 11 CME323 NUMERIC ANALYSIS. Lect. Yasin ORTAKCI.

ATILIM UNIVERSITY Department of Computer Engineering

HSancak Nesne Tabanlı Programlama I Ders Notları

TEMPLATES. Binnur Kurt Bilgisayar Mühendisliği Bölümü İstanbul Teknik Üniversitesi. C++ ile Nesneye Dayalı Programlama 1

MATLAB a GİRİŞ. Doç. Dr. Mehmet İTİK. Karadeniz Teknik Üniversitesi Makine Mühendisliği Bölümü

Program Nedir? Program, bir problemin çözümü için herhangi bir programlama dilinin kuralları ile oluşturulmuş komut kümesidir.

Konular. Hafta 5 Veri Tipleri (Devam) BLG339 PROGRAMLAMA DİLLERİ KAVRAMI

PROGRAMLAMAYA GİRİŞ DERS 2

Sınıflar ve Yapılar Arasındaki Farklılıklar. Değer ve Referans Türde Olan Aktarımlar

Bilgisayar Bilimcileri Haklıymış

ENF102 TEMEL BİLGİSAYAR BİLİMLERİ VE C/ C++ PROGRAMLAMA DİLİ. Gazi Üniversitesi Mühendislik Fakültesi Bilgisayar Mühendisliği Bölümü

Pythonda değişkenlerin türlerini tanımlamaya gerek yoktur

#include <stdio.h> int main(void) { float sayi; float * p; p = &sayi; printf("deger girin:"); scanf("%f", p); printf("girilen deger:%f\n", *p);

Final Sınavı Soruları Güz, Süre: 90 Dakika

VERİ YAPILARI DERS NOTLARI BÖLÜM 1 GİRİŞ. Yard. Doç. Dr. Deniz KILINÇ

DÖNGÜLER (LOOPS) while(), do-while(), for(), foreach()

/ C Bilgisayar Programlama Yıliçi Sınavı Test Soruları. Adı soyadı :... Öğrenci no :... İmza :... Tarih, Süre : , 60 dak.

Konular. Hafta 2 BLG339 PROGRAMLAMA DİLLERİ KAVRAMI

BBS 514 YAPISAL PROGRAMLAMA (STRUCTURED PROGRAMMING)

1. Aşağıdaki program parçacığını çalıştırdığınızda result ve param değişkenlerinin aldığı en son değerleri ve programın çıktısını yazınız.

İlk Konsol Uygulamamız 2 İlk Windows Uygulamamız 9.Net Framework Yapısı 18 Neler Öğrendik 19. Veri Tipleri 24 Tanımlı Veri Tipleri 27 Basit Tipler 28

A Y I K BOYA SOBA SOBA =? RORO MAYO MAS A A YÖS / TÖBT

Fonksiyonlar. C++ ve NESNEYE DAYALI PROGRAMLAMA 51. /* Fonksiyon: kup Bir tamsayının küpünü hesaplar */ long int kup(int x) {

Bağlama (Binding) Kavramı

Final Sınavı Örnek Soruları Bahar 2018

İfadeler bir programlama dilinde hesaplamaları belirtmede temel araçtır. İfadelerin değerlendirmesini anlamak için,

BİL-142 Bilgisayar Programlama II

Final Sınavı Soruları Bahar 2018

Mezun ( ) Sınav Salon Numarası GENEL AÇIKLAMA (GENERAL INSTRUCTIONS) In the test,

Mühendislik Fakültesi Elektrik-Elektronik Mühendisliği C Programlama 7. Bölüm Metot Tanımlama ve Kullanma

BİLG Dr. Mustafa T. Babagil 1

GÜZ YY. - MKT103 - GÖRSEL PROGRAMLAMA DERSİ - ARA SINAVI

BİLİNİRLİK ALANI ve ÖMÜR, KONTROL DEYİMLERİ

Internet Programming II. Elbistan Meslek Yüksek Okulu Bahar Yarıyılı

1 RUBY HAKINDA 1 Ruby nin Gelişim Hikayesi 1 Neden Ruby? 1 Neden Bu Kadar Popüler? 2

Bilgisayar Mühendisliğine Giriş. Yrd.Doç.Dr.Hacer KARACAN

while(), do-while(), for() M.İLKUÇAR 2010 MAKU-MYO

#include <stdio.h> int main(void) { FILE * dosya; dosya = fopen("soru1.txt", "w"); fprintf(dosya, "Merhaba Dunya!"); fclose(dosya); return 0; }

Genel Programlama II

e-ledger Fields (e-defter Alanları)

BLM 112- Programlama Dilleri II. Hafta 5 İşaretçiler (Pointers)

ALGORİTMA VE PROGRAMLAMA I

Python ile Programlamaya Giriş DERS 9: FONKSİYONLAR DR. HÜSEYİN BAHTİYAR

Bölüm 6. Karma. Olcay Taner Yıldız. O. T. Yıldız, C && Java ile Veri Yapılarına Giriş, Boğaziçi Üniversitesi Yayınevi, / 31

Operatörlere İşlev Yükleme

ALGORİTMA VE PROGRAMLAMA I

7.1- C#.net Giriş Çıkış İşlemleri ve Visual Studio. M.İLKUÇAR - 1

Ruby. Prof.Dr.Timur Karaçay Başkent Üniversitesi

BMH-303 Nesneye Yönelik Programlama

Algoritmalar ve Karmaşıklık

Sınav tarihi : Süre : 60 dak. a) ABCDE b) BCDE c) ABCD d) kod hatalı e) BCD

Adı soyadı :... Öğrenci no :... İmza :... Tarih, Süre : dak.

En kucuk calisabilir birime satetement denir Statements semicolon (;) ile sonlanir Yalniz basina ; null statement i ifade eder

C++ Statements. { ve } arasında ifade edilen bir dizi statement bir compound statement (birleşik ifade) oluşturur.

Java da İşleçler, Ders #3 (4 Kasım 2009)

İsimler ve Kapsam. Hafta 4 Ders 2 BLG339 PROGRAMLAMA DİLLERİ KAVRAMI

İçerik. Java da İşleçler, İşleçler. Aritmetik İşleçler - 1. Aritmetik İşleçler - 2. Geçen ders: Bu ders: BS-515 Nesneye Yönelik Programlama

-A Grubu- MKT103 Görsel Programlama 2015/2016 Güz Dönemi Final Sınavı

KOCAELİ ÜNİVERSİTESİ BİLGİSAYAR MÜHENDİSLİĞİ. BİLGİSAYAR LABORATUVARI II FİNAL SINAVI SORU ve CEVAPLARI(I. ogr)

BLM-112 PROGRAMLAMA DİLLERİ II. Ders-3 İşaretçiler (Pointer) (Kısım-2)

BLM210 HAFTA 2 FORMAL METHODS OF SYNTAX DESCRIPTION (SÖZDİZİM TARİFİNİN BİÇİMSEL YÖNTEMLERİ)

Pointer Kavramı. Veri Yapıları

Yazılım Nedir? 2. Yazılımın Tarihçesi 3. Yazılım Grupları 4 Sistem Yazılımları 4 Kullanıcı Yazılımları 5. Yazılımın Önemi 6

8. İŞARETCİLER (POINTERS)

Lambda, Map, Filter ve Dizi Tamamlama

Manisa Celal Bayar Üniversitesi Yazılım Mühendisliği Bölümü YZM Yapay Zekâ Dersi. Final Soruları A KİTAPÇIĞI. Güz,

Endüstri Mühendisliği Bölümü Bilgisayar Programlama Ders Notları

Tokenlarin Taninmasi

Transkript:

A grubu Pamukkale Üniversitesi Bilgisayar Mühendisliği Programlama Dilleri Dönem Sonu Sınavı Cevap Kağıdı 29.03.2017 Öğrenci Numarası : Adı Soyadı : Sınav çoktan seçmeli ve klasik olmak üzere iki kısımdan oluşmaktadır. Çoktan seçmeli kısmın cevapları optik okuyucuya uygun cevap kağıtları üzerine işaretlenecektir. İlk 30dk sonunda optik cevap kağıtları toplanacaktır. Kalan klasik soruları bu süreden sonra cevaplayabilirsiniz. Grubunuzu işaretlemeyi unutmayınız! Soru 1 2 3 4 5 6 Toplam Puan 50 10 10 10 10 10 100 Not 1. (1) (2P) Programlama dilleri hakkında aşağıdakilerden hangisi doğrudur?(which of the following statements about a programming language is correct?) A. Sözdizimi dilin yapısını, semantik ise anlamını ifade eder.(syntax refers to the structure of the language, while semantics refers to the meaning of the language.) B. Semantik dilin yapısını, sözdizimi anlamını ifade eder.(semantics refers to the structure of the language, while syntax refers to the meaning of the language.) C. Sözdizimi dilin yapısını, soyutlama anlamını ifade eder.(syntax refers to the structure of the language, while abstraction refers to the meaning of the language.) D. Semantik dilin yapısını, soyutlama anlamını ifade eder.(semantics refers to the structure of the language, while abstraction refers to the meaning of the language.) (2) (2P) Haskell dilinde lambda sembolünü hangi karakter temsil eder?(in the Haskell language, the character represents the lambda.) A. backslash (\) B. vertical bar ( ) C. underscore ( ) D. ampersand (&) (3) (2P) otomatik olarak BNF tanımlamalarını ayrıştırıcılara dönüştürürler.( automatically translate a BNF description into a parser.) A. Sözdizimi üreticileri(syntax generators) B. Tarayıcılar(Scanners) C. Kaydır-azalt ayrıştırıcılar(shift-reduce parsers) D. Ayrıştırıcı üreticiler(parser generators) (4) (2P) Tip kontrolünü çalışma zamanına ötelemenin getirisi nedir?(the real benefit of deferring type checking until runtime is.) A. daha yüksek program güvenilirliği(higher program reliability) B. daha iyi programcı verimliliği(greater programmer efficiency) C. daha yüksek program güvenliği(higher program safety) D. daha iyi çalışma zamanı verimliliği(greater runtime efficiency) (5) (2P) Global bir değişken aynı isimle yerel bir blok içinde tanımlanırsa ona denir.(a variable declared locally within a block is said to a global variable of the same name.) A. ayna(mirror) B. etkisiz kılan(override) C. önleyen(occlude) D. gölge(shadow) (6) (2P) Dinamik tahsis değişkenleri nereye yerleştirir?(dynamic allocation places variables.) A. sembol tablosuna(in the symbol table) B. yığın alanına(on the stack) C. işaretçi listesine(in the pointer list) D. heap alanına(on the heap) Sınav Süresi: 90dk 1 / 6 Başarılar

(7) (2P) Lisp programlama modeline dayanır.(lisp is based on the model of computation.) A. buyurucu(imperative) B. fonksiyonel(functional) C. yorumlamalı(interpretive) D. anlamsal(semantic) (8) (2P) Gramer kuralları olarak da adlandırılır.(grammar rules are also called.) A. yönerge(instructions) B. belgeleme(documentation) C. üretim(productions) D. derleme(compilations) (9) (2P) Hangisi genellikle yükleme zamanında bağlanır?( are generally bound at load time.) A. Öntanımlı belirleyiciler(predefined identifiers) B. Global değişkenler(global variables) C. Tüm özellikler(all attributes) D. Tüm değişkenler(all variables) (10) (2P) Python başlangıçta için tasarlanmıştır.(python was originally designed for.) A. geniş ölçekli sistemler(large scale systems) B. zamanın önemli olduğu sistemler(timecritical systems) C. bilim adamları, mühendisler ve programcı olmayan diğerleri(scientists and engineers and other non-programmers) D. uzman programcılar(expert programmers) (11) (2P) Değişkenler, kullanarak bir isim ve tip kazanırlar.(variables are given names and data types using a.) A. yapı(structure) B. fonksiyon(function) C. bildirim(declaration) D. paket(package) (12) (2P) Düzenli ifadelerde tekrar sembolü ile gösterilir.(in a regular expression, repetition is indicated by.) A. a vertical bar ( ) B. an exclamation mark (!) C. an asterisk (*) D. a hyphen (-) (13) (2P) C dilinde fonksiyonlardan geri dönüş tipi olarak dizilerin kullanılamaması hangi özelliğin eksik olduğunu gösterir?(the fact that C does not allow array types to be the return value of a function indicates a lack of in the language.) A. ortogonallik(orthogonality) B. genellik(generality) C. tekbiçimlilik(uniformity) D. verimlilik(efficiency) (14) (2P) Boş alan karakterlerinin işlenmesi genellikle tarafından ele alınır.(the processing of white space is generally handled by a.) A. kestirimci ayrıştırıcı(predictive parser) B. tarayıcı(scanner) C. ayrıştırıcı(parser) D. ayrıştırıcı üretici(parser generator) (15) (2P) Aşağıdakilerden hangisi kaynak kodu girdi olarak alır ve çalıştırılabilir bir programa dönüştürür?(a(n) takes source code as input and translates it into a program that is executable.) A. bağlayıcı(linker) B. yükleyici(loader) C. derleyici(compiler) D. yorumlayıcı(interpreter) (16) (2P) Eğer bir işleç birden fazla fonksiyona karşılık geliyorsa ona denir.(if an operator performs more than one function it is said to be.) A. aşırı yüklenmiş(overloaded) B. örtülü(implicit) C. değişken(variable) D. gölgelenmiş(shadowed) Sınav Süresi: 90dk 2 / 6 Başarılar

(17) (2P) Haskell ile ilgili aşağıdakilerden hangisi doğrudur?(which of the following statements about Haskell is correct?) A. Haskell tamamıyla curry özelliğini desteklemeyen tembel bir dildir.(haskell is a lazy language that is not fully curried.) B. Haskell tamamıyla curry özelliğini destekleyen tembel bir dildir.(haskell is a fully curried and lazy language.) C. Haskell tamamıyla curry özelliğini destekleyen ve gecikmeli değerlendirmeye izin vermeyen bir dildir.(haskell is a fully curried language that does not do delayed evaluation.) D. Haskell yüksek-dereceli fonksiyonları desteklemez.(haskell does not support higherorder functions.) (18) (2P) C++ sınıf tanımlarından sonra noktalı virgül gerektirir fakat fonksiyon tanımlarından sonra gerektirmez. Bu özelliği ile C++ hangisini sağlamaz?(because C++ requires a semicolon after a class definition but not after a function definition, C++ is said to lack.) A. güvenilirlik(reliability) B. güvenlik(security) C. tekbiçimlilik(uniformity) D. ortogonallik(orthogonality) (19) (2P) Bir ayrıştırıcının en basit hali bir.(the simplest form of a parser is a(n).) A. yorumlayıcıdır(interpreter) B. çevirmendir(translator) C. tanıyıcıdır(recognizer) D. derleyicidir(compiler) (20) (2P) Aşağıdakilerden hangisi Scheme dilinde bir veri listesini temsil eder?(which of the following represents a list of data in Scheme?) A. (quote (3.1, 3.2, 3.3)) B. (3.1, 3.2, 3.3) C. (quote (3.1 3.2 3.3)) D. (3.1; 3.2; 3.3) (21) (2P) Aşağıdakilerden hangisi ML dilinde bir veri listesini temsil eder?(which of the following represents a list in ML?) A. (1, 2, 3) B. [1, 2, 3] C. {1 2 3} D. (1 2 3) (22) (2P) Bir metoda yapılan her çağrı olarak adlandırılır.(each call to a method is referred to as a(n).) A. dallanma(branching) B. başlatma(invocation) C. yürütme(execution) D. etkinleştirme(activation (23) (2P) Scheme dilinde ((x) (p q) t) listesi üzerinde (car (car (cdr L))) çağrısının sonucu nedir?(given a list L in Scheme with contents of ((x) (p q) t). What will be returned if the command (car (car (cdr L))) is executed?) A. (x) B. p C. (p) D. (p q) (24) (2P) Diziler aşağıdaki soyutlamalardan hangisidir?(an array is considered to be a.) A. yapısal veri soyutlaması(structured data abstraction) B. basit veri soyutlaması(basic data abstraction) C. basit kontrol soyutlaması(basic control abstraction) D. birim soyutlaması(unit abstraction) (25) (2P) Aşağıdaki dillerin hangisinde statik tip tanımlaması yoktur?(all of the following languages are statically typed except.) A. Python B. C C. C++ D. Ada Sınav Süresi: 90dk 3 / 6 Başarılar

2. (10P) Parametre olarak kelimelerin virgülle ayrıldığı bir string alan, bu kelimeleri alfabetik olarak sıralayıp yine virgülle ayrıldığı bir string döndüren Python metodunu yazınız. Örn: kalem,defter,elma,armut,kitap armut,defter,elma,kalem,kitap (Write the kelimesirala method which takes comma seperated numbers as a string, splits and sorts the numbers and returns the combined comma seperated numbers as string.) def kelimesirala(metin): kelimeler = metin.split(, ) kelimeler.sort() return,.join(kelimeler) 3. (10P) sayilar.txt isimli dosyada birden fazla satırda aralarında virgül karakteri bulunacak şekilde tamsayılar birbirinden ayrılmıştır. Bu sayıları dosyadan okuyup her satırda bir sayı olacak şekilde yazdıran Ruby kodunu yazınız.(there are multiple lines in sayilar.txt file and in every line there are comma seperated numbers. Write a Ruby program that reads numbers from the file and prints a number each line.) File.open( sayilar.txt ) do kayit kayit.each do satir sayilar = satir.split(",") sayilar.each do deger puts deger end end end 4. (10P) Aşağıda bir dizideki en büyük sayıyı bulmak için enbuyuk fonksiyonunun prototipi C dilinde verilmiştir. enbuyuk fonksiyonunu atama ve döngü işlemleri olmadan(mümkün olduğunca fonksiyonel) ve kuyruk özyinelemeli olarak yazınız ve main fonksiyonu içinden enbuyuk fonksiyonunun nasıl çağrılacağını gösteriniz.(below is the prototype of a function which finds the maximum number in an array. Write tail recursive enbuyuk function without using assignment and loops. Also in main, write function call properly.) int enbuyuk(int dizi[], int es, int max) { if(es==-1) return max; if(dizi[es]>max) return enbuyuk(dizi, es-1, dizi[es]); else return enbuyuk(dizi, es-1, max); } void main() { int dizi[]={12,1,4,21,3,99}; printf("%d\n", enbuyuk(dizi,5,dizi[5])); } Sınav Süresi: 90dk 4 / 6 Başarılar

5. (10P) Aşağıdaki gramerin başlangıç sembolü P dir. Belirtilen giriş cümlesi verildiğinde oluşan sözdizim ağacını çiziniz.(the start symbol of the grammar below is P. Draw the parse tree using the input string below.) P S S P S SY. K K yaz SY g i t SY b a s l a b i t i s eger KS i s e K KS SY < SY SY = SY SY > SY SY 1 2 3 4 5 6 7 8 9 0 Giriş cümlesi: 1. b a s l a 2. eger 3>5 i s e g i t 1 3. b i t i s Sınav Süresi: 90dk 5 / 6 Başarılar

6. Aşağıdaki C kodu için kullanılan kapsama göre çıktıları yazınız.(write the output of the C code below when specific scoping is used.) 1 int x; 2 int main() { 3 x = 14; 4 f(); 5 g(); 6 } 7 void f() { 8 int x = 13; 9 h(); 10 } 11 void g() { 12 int x = 12; 13 h(); 14 } 15 void h() { 16 printf("%d\n",x); 17 } (1) (5P) Statik kapsam(lexical scope) 14 14 (2) (5P) Dinamik kapsam(dynamic scope) 13 12 Sınav Süresi: 90dk 6 / 6 Başarılar