கணினி அறிவியல் : தரவு அருவமாக்கம்
மதிப்பீடு
பகுதி – அ
சரியான விடையை தேர்ந்தெடுத்து எழுதுக (1 மதிப்பெண்கள்)
1. பின்வரும் எந்த செயற்கூறு அருவமாக்கம்
தரவு வகையை உருவமைக்கப் பயன்படுகிறது?
அ) Constructors
ஆ)
Destructors
இ)
recursive
ஈ)
Nested
விடை : அ)
Constructors
2. பின்வரும் எந்த செயற்கூறு தரவு
வகையில் இருந்து தகவல்களை மீட்டெடுக்கும்?
அ)
Constructors
ஆ)
Selectors
இ)
recursive
ஈ)
Nested
விடை : ஆ)
Selectors
3. வரிசைப்படுத்தப்பட்ட உருப்புகளை
மாற்றக்கூடிய தரவு கட்டமைப்பு
அ)
Built in
ஆ)
List
இ)
Tuple
ஈ)
Derived data
விடை : ஆ) List
4. மாற்ற செய்ய முடியாத பொருளின்
தொடர் வரிசை
அ)
Built in
ஆ)
List
இ)
Tuple
ஈ)
Derived data
விடை : இ)
Tuple
5. உருவமைப்பு அறியப்பட்ட தரவு
வகை எவ்வாறு அழைக்கப்படுகிறது?
அ)
Built in datatype
ஆ)
Derived datatype
இ)
Concrete datatype
ஈ)
Abstract datatype
விடை : இ)
Concrete datatype
6. உருவமைப்பு அறியப்படாத தரவு
வகை எவ்வாறு அழைக்கப்படுகிறது?
அ)
Built in datatype
ஆ)
Derived datatype
இ)
Concrete datatype
ஈ)
Abstract datatype
விடை : ஈ)
Abstract datatype
7. பின்வருவனவற்றில் எது கலவை
அமைப்பு?
அ) Pair
ஆ)
Triplet
இ)
Single
ஈ)
quadrat
விடை : அ) Pair
8. இரு மதிப்புகளை ஒன்றாக பிணைக்க
எந்த வகை கருதப்படுகிறது.
அ)
Pair
ஆ)
Triplet
இ)
Single
ஈ)
quadrat
விடை : அ) Pair
9. பின்வருவனவற்றில் எது பல் உருப்பு
பொருளின் பல்வேறு பகுதிகளை பெயரிட அனுமதிக்கிறது?
அ)
Tuples
ஆ)
Lists
இ)
Classes
ஈ)
quadrats
விடை: இ) Classes
10. பின்வருவனவற்றில் எது கோவைகளை
சதுர அடைப்புக்குறிக்குள் வைத்து உருவமைகிறது?
அ)
Tuples
ஆ)
Lists
இ)
Classes
ஈ)
quadrats
விடை : ஆ)
Lists
பகுதி - ஆ
அனைத்து வினாக்களுக்கும்
விடையளி (2 மதிப்பெண்கள்)
1. தரவு அருவமாக்கம் வகை என்றால்
என்ன?
விடை. (i) அருவமாக்க தரவு வகை (Abstract Data type (ADT)) என்பது பொருள்களுக்கான
வகை (அல்லது இனக்குழு ஆகும், இதன் செயல் மதிப்பின் தொகுப்பு மற்றும் செயல்பாடுகளின்
தொகுப்பால் வரையறுக்கப்படுகிறது.
(ii) ADT யின் வரையறுப்பு என்ன வகையான செயல்பாடுகள் செய்யப்படவேண்டும்
என்று குறிப்பிடுகின்றது, அவை எப்படி செயல்பட வேண்டும் என்று குறிப்பிடப்படுவதில்லை.
(iii) இவை தரவுகள் நினைவகத்தில் எவ்வாறு சேமிக்கப்படுகின்றது என்றோ
அல்லது எந்த நெறிமுறைகள் செய்யப்பட வேண்டும் என்ற வழிமுறையோ குறிப்பிடப்படுவதில்லை
.
(iv) சுயமாக இவை செயல்படுத்தப்படுவதில்லை எனவே, இதை அருவமாக்கம் என்று
அழைக்கிறோம். விவரங்களை மறைத்து அவசியமானவற்றை மட்டும் வழங்கும் செயல்முறையை அருவமாக்கம்
என்கிறோம்.
2. ஆக்கிகள் மற்றும் செலக்டர்கள்
வேறுபாடு தருக.
விடை. ஆக்கி செயற்கூறுகள் அருவமாக்கம் தரவு வகையை கட்டமைக்க பயன்படுகிறது.
செலக்டர் செயற்கூறுகள் தகவல்களை தரவு வகையிலிருந்து பெறுவதற்கு பயன்படுகிறது.
3. Pair என்றால் என்ன? எடுத்துக்காட்டு தருக.
விடை. இரு மதிப்புகளை ஒன்றாக இணைக்கும் முறையை Pairs என்று அழைக்கிறோம்.
List அதிகமாக பயன்படுத்தப்படும் முறையாகும். எனவே, List, Pairs என்று அழைக்கப்படுகிறது.
எ.கா. List = [10, 20, 30]
4. List என்றால் என்ன? எடுத்துக்காட்டு
தருக.
விடை. List அமைப்பு கோவைகளை சதுர அடைப்புக்குறிக்குள் காற்புள்ளியில் பிரிக்கப்பட்டிருக்கும்.
இக்கோவைகளை List literal என்று அழைக்கப்படுகிறது. List பல மதிப்புகளை சேமிக்கும் இம்மதிப்புகள்
எவ்வகையாகவும் இருக்கலாம் அல்லது மற்றொரு லிஸ்டாகவும் இருக்கலாம்.
எ.கா. List = [10, 20]
5. Tuple என்றால் என்ன? எடுத்துக்காட்டு
தருக.
விடை. Tuple என்பது அடைப்புக்குறிக்குள் கொடுக்கப்பட்டுள்ள தொடர் மதிப்புகளை
காற்புள்ளியில் பிரிக்கப்பட்டிருக்கும். tuple என்பது List போன்றதாகும். இவை இரண்டிற்கும்
உள்ள வேறுபாடு என்னவென்றால் tuple-ல் கொடுக்கப்பட்ட உறுப்புகளை மாற்ற முடியாது ஆனால்
List-ல் இடம்பெற்றுள்ள உறுப்புகளை மாற்றலாம்.
எ.கா. colour = ('red', 'blue', 'Green')
பகுதி - இ
அனைத்து வினாக்களுக்கும்
விடையளி (3 மதிப்பெண்கள்)
1. கான்கிரிட் தரவு வகை மற்றும் அருவமாக்கம் தரவு வகை வேறுபடுத்துக.
விடை. கான்கிரிட்
தரவு
கான்கீரிட் தரவு வகை (CDT's) அல்லது ஸ்டக்சர்ஸ் எளிய கருத்தினை செயல்படுத்த
உதவுகிறது.
அருவமாக்கம்
அருவமாக்கம் தரவு வகை
(ADT's) ஒரு கருத்து எவ்வாறு செயல்படுத்தப் படுகின்றது என்பதை தவிர்த்து, அக்கருத்து
பற்றிய உயர் நிலை பார்வை (மற்றும் பயன்பாடு) வழங்குகிறது.
2. நிரல் வடிவமைப்பில் பின்பற்றப்படும்
யுக்தி எது? யுக்தியை வரையறுக்க.
விடை. (i) விஸ்புல் திங்கிங் என்ற சக்தி வாய்ந்த செயல் யுக்தியை பயன்படுத்தி
நிரல் வடிவமைக்கப்படுகின்றது.
(ii) விஸ்புல் திங்கிங் என்பது யதார்த்தத்திற்கு பதிலாக நம்பிக்கையின்
அடிப்படையில் விருப்பத்திற்கு ஏற்ப முடிவெடுப்பதாகும்.
3. பின்வருவனவற்றில் எது
constructors and selectors என்று அடையாளம் காணவும்?
(a) N1 = number()
(b) accetnum(n1)
(c) displaynum(n1)
(d) eval(a/b)
(e) x,y=makeslope(m),
makesloper(n)
(f) display()
விடை. (i) a. Constructor
(ii) b. Selector
(iii) c. Selector
(iv) d. Constructor
(v) e. Constructor
(vi) f. Selector
4. List உள்ள உருப்புகளை அணுகும்
பல்வேறு வழிமுறைகள் யாவை? எடுத்துக்காட்டு தருக.
விடை. (i) list -ன் உறுப்புகளை இரு வழியில் அணுகலாம். முதல் வழி, அதிகம்
பயன்படுத்தப்படும் பன்மடங்கு மதிப்பிருத்தல். இம்முறையில், list-ன் உறுப்புகள் பிரிக்கப்பட்டு,
அனைத்து உறுப்புகளும் வேறு பெயர்களுடன் இணைக்கப்படுகிறது.
1st := [10, 20]
x,y := 1st
(ii) மேலே காணும் எடுத்துக்காட்டில், Xயின் மதிப்பு 10 என்றும், Yயின்
மதிப்பு 20 என மதிப்பிருத்தப்படும்.
(iii) இரண்டாம் முறையில் லிஸ்டின் உறுப்புகள், உறுப்புகள் தேர்வு மூலம்
அணுகப்படுகிறது. செயற்குறிகள் சதுர அடைப்புக்குறிக்குள் கொடுக்கப்பட்டிருக்கும்.
(iv) லிஸ்ட் லிட்டரல்ஸ் போல் அல்லாது கோவையில் ஒரு சதுர அடைப்புக்குறியை
தொடர்ந்து வரும் மற்றொரு சதுர அடைப்புக்குறி லிஸ்டின் மதிப்புகளாக எடுத்துக்கொள்ளப்படுவதில்லை.
மாற்றாக முந்தய கோவையின் உறுப்பை மதிப்பாக தேர்வு செய்யும்.
1st [0]
10
1st[1]
20
5. பின்வருவனவற்றில் எது
List, Tuple எது மற்றும் இனக்குழு (class) என அடையாளம் காண்க.
(a) arr [1, 2, 34]
(b) arr (1, 2, 34)
(c) student [rno, name,
mark]
(d) day= ('sun', 'mon',
'tue', 'wed')
(e) x = [2, 5, 6.5, [5, 6],
8.2]
(f) employee [eno, ename,
esal, eaddress]
விடை . (i) a. List
(ii) b. Tuple
(iii) c. Class
(iv) d. Tuple
(v) e. List
(vi) f. Class
பகுதி - ஈ
அனைத்து வினாக்களுக்கும்
விடையளி (5 மதிப்பெண்கள்)
1. தரவு அருவமாக்கம் எவ்வாறு செயல்படுத்துவாய்?
எடுத்துக்காட்டுடன் விளக்குக.
விடை. தரவு அருவமாக்கினை செயல்படுத்த, ஆக்கிகள் (Constructor) மற்றும் செலக்டர்
(Selectors) என்ற இரண்டு செயற்கூறுகள் உருவாக்கப்பட வேண்டும்.
ஆக்கிகள் மற்றும்
செலக்டர்கள் (constructors and selectors) :
(i) ஆக்கி செயற்கூறுகள் அருவமாக்கம் தரவு வகையை கட்டமைக்க பயன்படுகிறது.
செலக்டர் செயற்கூறுகள் தகவல்களை தரவு வகையிலிருந்து பெறுவதற்கு பயன்படுகிறது.
(ii) எடுத்துக்காட்டாக, city என்று ஒரு அருவமாக்க தரவு வகை உள்ளது என
வைத்துக்கொள். City என்ற பொருள் நகரத்தின் பெயர், அட்சரேகை மற்றும் தீர்க்கரேகை பற்றிய
தகவல்களை சேமித்திருக்கும் city என்ற பொருளை உருவாக்க பின்வரும் செயற்கூற்றினை பயன்படுத்தலாம்.
city == makecity (name, lat, lon)
(iii) city பொருளின் தகவல்களை பெறுவதற்கு பின்வரும் செயற்கூறுகளை பயன்படுத்தலாம்.
* getname(city)
* getlat(city).
* getlon(city)
(iv) பின்வரும் போலி குறிமுறை இரு நகரங்களுக்கு இடையேயான தொலைதூரத்தை
கணக்கிடும்.
distance(city1, city2):
lt1, lg1 := getlat(city1), getlon(city1)
It2, Ig2:= getlat (city2), getlon (city2)
return (1t1 - 1t2)**2 + (1g1-1g2)**2)1/2
(v) மேலே காணும் குறிமுறையில், distance(),getlat() மற்றும்
getlon() ஆகியவை செயற்கூறுகள் ஆகும். It என்பது அட்ச ரேசை மற்றும் 1g என்பது தீர்க்க
ரேகையும் குறிக்கிறது. longitude. := என்பதை "assigned as" அல்லது
"becomes" என்று வாசிக்க வேண்டும்.
It 1, lg1 := getlat(city1), getlon(city1)
(vi) இதனை 1t1 என்பது getlat(city1)ன் மதிப்பாகிறது மற்றும் 1g1 என்பது
getlont(city1) ன் மதிப்பாகிறது. என்று வாசிக்க வேண்டும்.
(vii) இந்த செயற்கூறுகள் எவ்வாறு செயல்படுத்தப்படுகிறது என்பதை தெரிந்து
கொள்ள வேண்டியதில்லை. இதை வேறு ஒருவர் நமக்காக வரையறுத்துள்ளார் என்று கருதிக் கொள்ள
வேண்டும். பயனர் செயற்கூறுகள் எப்படி செயல்படுத்தப்படுகின்றது என்பது தெரிந்து வைத்திருக்க
வேண்டியதில்லை எனினும் வேறு ஒருவரால் இச்செயற்கூறுகள் வரையறுக்கப்பட்டிருக்க வேண்டும்.
(viii) மேலே காணும் குறிமுறையில், ஆக்கி மற்றும் செலக்டர்களை அடையாளம்
காண்போம். கண்ஸ்டரக்டர்ஸ் செயற்கூறுகள் அருவமாக்க தரவு வகையை கட்டமைக்கப் பயன்படுகிறது
என்பதை நாம் அறிவோம். மேலே காணும் போலிக் குறிமுறையில், cityயின் பொருளை உருவாக்கும்
செயற்கூறு, ஆக்கி ஆகும்.
city = makecity(name, lat, lon) இங்கு makecity(name, lat, lon) என்ற
ஆக்கி city எனும் பொருளை உருவாக்குகிறது.
(ix) செலக்டார் செயற்கூறுகுள் தகவல்களை தரவு வகையிலிருந்து பெறுவதற்கு
பயன்படுகிறது. மேலே காணும் குறிமுனையில்,
* getname(city)
* getlat(city)
* getlon(city) என்பவை city எனும் பொருளிலிருந்து தகவல்களை பெற்றுத்
தரும் செலக்டர் செயற்கூறுகளாகும்.
2. List என்றால் என்ன? ஏன்
List, Pairs என்று அழைக்கப்படுகிறது. எடுத்துக்காட்டுடன் விவரி.
விடை. தரவு அருவமாக்கினை ஸ்திரமுடன் செயல்படுத்த, பைதான் போன்ற மொழிகள் பேர்ஸ்
எனும் கூட்டு அமைப்பை வழங்குகிறது. இவை லிஸ்ட் மற்றும் டூபுல்ஸ் ஆகியவற்றால் உருவாக்கப்படுகிறது.
பேர்ஸ்சை, லிஸ்ட் கொண்டு எளிதாக செயல்படுத்தலாம்.
List:
(i) List அமைப்பு கோவைகளை சதுர அடைப்புக்குறிக்குள் காற்புள்ளியில்
பிரிக்கப்பட்டிருக்கும். இவ்கோவைகளை List literal என்று அழைக்கப்படுகிறது. List பல
மதிப்புகளை சேமிக்கும் இம்மதிப்புகள் எவ்வகையாகவும் இருக்கலாம் அல்லது மற்றொரு லிஸ்டாகவும்
இருக்கலாம்.
எடுத்துக்காட்டு List = 10, 20.
(ii) list-ன் உறுப்புகளை இரு வழியில் அணுகலாம். முதல் வழி, அதிகம் பயன்படுத்தப்படும்
பன்மடங்கு மதிப்பிருத்தல். இம்முறையில், list-ன் உறுப்புகள் பிரிக்கப்பட்டு, அனைத்து
உறுப்புகளும் வேறு பெயர்களுடன் இணைக்கப்படுகிறது.
1st := 10, 20
x, y := 1st
மேலே காணும் எடுத்துக்காட்டில், Xயின் மதிப்பு 10 என்றும், Y யின் மதிப்பு
20 என மதிப்பிருத்தப்படும்.
(iii) இரண்டாம் முறையில் லிஸ்டின் உறுப்புகள், உறுப்புகள் தேர்வு மூலம்
அணுகப்படுகிறது. செயற்குறிகள் சதுர அடைப்புக்குறிக்குள் கொடுக்கப்பட்டிருக்கும். '
லிஸ்ட் லிட்டரல்ஸ் போல் அல்லாது கோவையில் ஒரு சதுர அடைப்புக்குறியை தொடர்ந்து வரும்
மற்றொரு சதுர அடைப்புக்குறி லிஸ்டின் மதிப்புகளாக எடுத்துக்கொள்ளப்படுவதில்லை. மற்றாக
முந்தய கோவையின் உறுப்பை மதிப்பாக தேர்வு செய்யும்.
Isto
10
1st1
20
மேலே காணும் எடுத்துக்காட்டினை கணித முறையில் set போன்று அமைக்கலாம்.
1st[(0, 10), (1, 20)] - where
(iv) இரு மதிப்புகளை ஒன்றாக இணைக்கும் முறையை Pairs என்று அழைக்கிறோம்.
List அதிகமாக பயன்படுத்தப்படும் முறையாகும். எனவே, List, Pairs என்று அழைக்கப்படுகிறது.
3. பல் உருப்பு பொருளை எவ்வாறு
அணுகுவாய் எடுத்துக்காட்டுடன் விளக்கு.
விடை. (i) structure அமைப்பை (OOP மொழியில் இது இனக்குழு அமைப்பு என்று அழைக்கப்படுகிறது)
கொண்டு பல உருப்படி பொருளில் அனைத்து உருப்புகளும் பெயரிடப்படும் பெயர் கொடுக்கப்பட்டு
பின்வரும் போலிக்குறிமுறையை காணவும்:
class Person:
creation()
firstName :=" "
lastName :=" "
id := “ “
email :=" "
Person எனும் புதிய தரவு வகையை படவடிவில் உருவமைக்கலாம்.
(ii) இனக்குழு கட்டமைப்பு ஒரு நபரை குறிக்கும் பல பகுதி பொருளுக்கு
வடிவம் வரையறுக்கிறது. இந்த வரையறுப்பு புதிய தரவு வகையை சேர்க்கிறது. இதில் நபர் என்பது
வகையாகும். ஒரு முறை வரையறுத்தலின், நாம் புதிய மாறிகளை உருவாக்கலாம்.
(iii) இந்த எடுத்துக்காட்டில் Person என்பது இனக்குழு அல்லது வகையாகும்.
p1 என்பது தனிப்பட்ட குக்கீ குறிக்கின்றது. குக்கீ கட்டர் கொண்டு பல குக்கீகளை தயாரிக்கலாம்.
அது போன்று இவ்இனக்குழுவைக் கொண்டு பல பொருள்களை உருவாக்கலாம்.
(iv) இதுவரை, இனக்குழு தொடர்புடைய தரவுகளைக் கொண்டு தரவு அருவமாக்கத்தை
எவ்வாறு வரையறுக்கிறது என்று பார்த்தோம். ஓர் இனக்குழு என்பது தரவுகளை மட்டுமில்லாது
செயற்கூற்றினையும் தன்னுடன் கொண்டிருக்கும்.
(v) இவ்வகை செயற்கூறுகள், இனக்குழுவிற்கு கீழ்படந்தவை, ஏனெனில் இவை
இனக்குழுவின் தரவுகளை வைத்து செயல்படுகிறது.
(vi) எடுத்துக்காட்டு Person பொருளின் தரவுகளை மாற்றம் செய்தல் அல்லது
ஆய்வு செய்தல் எனவே, இனக்குழு என்பது தரவு மற்றும் அத்தரவின் மீது செயலாற்றும் செயற்கூறுகளை
கொண்ட தொகுப்பாகும்.
(vii) முன்னதாக பார்த்த எடுத்துக்காட்டு மற்றும் விளக்கத்தின் மூலம் அருவமாக்கம் என்பது சிக்கலான தரவுகளை எளிய முறையில் கையாள உதவுகின்றது என்பதை உணரலாம்.