PYTHON
>> Sunday, May 30, 2010
കംപ്യൂട്ടര് പ്രോഗ്രാമിംഗ് എന്ത്/എങ്ങനെ
കംപ്യൂട്ടര് എന്താണെന്ന്
നമുക്കെല്ലാം ഇന്നറിയാം -- നമ്മില് ചിലരെങ്കിലും കംപ്യൂട്ടര് നിത്യേനയോ
നിത്യേനയെന്നോണമോ ഉപയോഗിക്കുന്നവരാണ്. കംപ്യൂട്ടര് പ്രോഗ്രാമിംഗ് പക്ഷേ
ഇന്നും കുറെയൊക്കെയെങ്കിലും നമുക്കൊരു അപരിചിതവസ്തുവാണ്. ഈ അവസ്ഥ ഇതാ
മാറാന് പോകുന്നു!ലളിതമായി പറഞ്ഞാല് കംപ്യൂട്ടറിന് നിര്ദ്ദേശങ്ങള് കൊടുത്ത്, അതിനെക്കൊണ്ട് നമുക്കുവേണ്ട കാര്യങ്ങള് ചെയ്യിക്കാനുള്ള ഉപാധിയാണ് കംപ്യൂട്ടര് പ്രോഗ്രാമിംഗ് . കംപ്യൂട്ടര് വെറും യന്ത്രമായതുകൊണ്ടും, അതിനാല്ത്തന്നെ അതിന് നമുക്കുള്ളതുപോലെ ബുദ്ധിയോ ചിന്താശക്തിയോ വിവേചനശേഷിയോ ഒന്നും ഇല്ലാത്തതുകൊണ്ടും, വളരെ കൃത്യമായി കാര്യങ്ങള് പറഞ്ഞുകൊടുത്താലേ അത് എന്തും വേണ്ടരീതിയില് ചെയ്യൂ (ഇതൊക്കെയുണ്ടെങ്കിലും ഒന്നും വേണ്ടരീതിയില് ചെയ്യാത്ത മനുഷ്യരുണ്ടെന്നുള്ളത് വേറേകാര്യം). അതുകൊണ്ടുതന്നെ പ്രോഗ്രാമിംഗില് പ്രധാനമായും വേണ്ടത്, നമുക്കെന്താണ് ചെയ്തുകിട്ടേണ്ടത് എന്നു കൃത്യമായി മനസ്സിലാക്കാനും, മനസ്സിലാക്കിയതിനെ ലളിതമായ ഭാഷയില് കംപ്യൂട്ടറിന് പറഞ്ഞുകൊടുക്കാനും പഠിക്കുക എന്നതാണ്. ഇതത്ര ബുദ്ധിമുട്ടുള്ളതാണെന്നു തോന്നുന്നുണ്ടോ? അടിസ്ഥാന നിലവാരത്തിലുള്ള പ്രോഗ്രാമിംഗ് (നമ്മുടെ സ്കൂള് സിലബസിലെ പ്രോഗ്രാമിംഗ് നിശ്ചയമായും ഇതില്പ്പെടും) വലിയ പ്രയാസമൊന്നുമില്ലാത്ത, ശ്രദ്ധയോടെ കാര്യങ്ങള് ചെയ്യാനുള്ള ക്ഷമ മാത്രം ആവശ്യമുള്ള ഒന്നാണ്.
എന്താണ് പൈത്തണ്?
കംപ്യൂട്ടര് പ്രോഗ്രാമുകള് എഴുതാനുള്ള അനേകായിരം ഭാഷകളില് ഒന്നാണ് പൈത്തണ്. ഇത് തുടക്കക്കാര്ക്ക് പഠിക്കാന് എളുപ്പമുള്ള ഒരു ഭാഷയാണ്. എന്നാല് കംപ്യൂട്ടര് ഭാഷകളില്വച്ച് ഒട്ടും പിന്നിലല്ലതാനും. ഒരുദാഹരണം: ഗൂഗിളിന്റെ ആദ്യത്തെ ക്രൗളര് (ഇന്റര്നെറ്റിലൊക്കെ പോയി പുതിയ പേജുകള് വന്നിട്ടുണ്ടോ, പഴയ പേജുകള്ക്ക് മാറ്റങ്ങള് വന്നിട്ടുണ്ടോ എന്നൊക്കെ പരതുന്ന സോഫ്ട് വെയര് ) എഴുതിയത് പൈത്തണ് ഉപയോഗിച്ചാണെന്ന് പറയപ്പെടുന്നു.ഈ പാഠനപദ്ധതി ആര്ക്കൊക്കെ ഉപയോഗപ്പെടും?
ഒരുവിധം എല്ലാവര്ക്കും. അഞ്ചാംക്ളാസ് മുതല് മുകളിലേക്കുള്ള പ്രായക്കാര്ക്ക് ഇതില് മിക്കഭാഗവും മനസ്സിലാക്കാന് സാധിക്കേണ്ടതാണ്. അഞ്ചാംക്ളാസുകാരിയാണെങ്കില് മുതിര്ന്ന ഒരാളുടെ സഹായവും നല്ല ഇച്ഛാശക്തിയും വേണ്ടിവന്നേക്കാമെന്നത് വേറേകാര്യം. പ്രത്യേകം എടുത്തുപറയേണ്ട ഒരു കാര്യം, ഇതുപഠിക്കാന് ഗണിതശാസ്ത്ര സംബന്ധിയായ അഭിരുചിയോ താത്പര്യമോ വേണമെന്നില്ല എന്നതാണ്: "ലോജിക്കും" സാമാന്യബുദ്ധിയും മതി; പുതിയ കാര്യങ്ങള് പഠിക്കാനുള്ള താത്പര്യവും. നമ്മുടെ പഠനം പ്രധാനമായും പ്രശ്നനിര്ദ്ധാരണത്തെ (Problem Solving) അവലംബിച്ചായിരിക്കും. ചില "തറ പറ" ബാലപാഠങ്ങള് കഴിഞ്ഞാല്, പ്രോഗ്രാമിംഗ് പസിലുകളുടെ ഒരു ഉത്സവമായിരിക്കും അരങ്ങേറുക എന്നര്ത്ഥം. പ്രോഗ്രാമുകള് ചെയ്തുപഠിക്കുന്നതിലൂടെ, പൈത്തണ് എന്ന ഭാഷയുടെ വ്യാകരണം പഠിക്കുക എന്നതിലുപരി പ്രോഗ്രാമിംഗ് എന്ന കല നമുക്കു പഠിക്കാം.ഇതിന് എന്തൊക്കെ സജ്ജീകരണങ്ങളാണു വേണ്ടത്?
നമ്മുടെ സ്കൂളുകളില് ലഭ്യമായ ലിനക്സ് സിസ്റ്റങ്ങളില് പൈത്തണ് പ്രോഗ്രാമിംഗ് ചെയ്തുതുടങ്ങുന്നതിന് വേണ്ടതെല്ലാം സ്വതവേതന്നെ ലഭ്യമാണ്:- പ്രോഗ്രാമുകള് എഴുതാന് വേണ്ടി ഏതെങ്കിലും ഒരു എഡിറ്റര് . ഉദാ: gedit.
- പ്രോഗ്രാമുകള് പ്രവര്ത്തിപ്പിക്കാന് വേണ്ടി Python എന്ന പേരില്ത്തന്നെ അറിയപ്പെടുന്ന സോഫ്ട് വെയര് . ഇത് ടെര്മിനല് ഉപയോഗിച്ച് പ്രവര്ത്തിപ്പിക്കാം.
പ്രോഗ്രാമിംഗ് കുറച്ചുകൂടി എളുപ്പമാക്കുന്ന, Integrated Development Environment (IDE) എന്നറിയപ്പെടുന്ന സോഫ്ട് വെയറുകള് ലഭ്യമാണ്. ഇവയേപ്പറ്റി വഴിയേ പറയാം.
ഇനി നമുക്ക് നമ്മുടെ ആദ്യത്തെ പൈത്തണ് പ്രോഗ്രാം എഴുതി പ്രവര്ത്തിപ്പിച്ചുനോക്കാം.
നമ്മുടെ ആദ്യത്തെ പൈത്തണ് പ്രോഗ്രാം
പ്രോഗ്രാമുകള്ക്കു വേണ്ടി ഒരു ഡയറക്ടറി
നമ്മുടെ പ്രോഗ്രാമുകളൊക്കെ സൂക്ഷിച്ചുവെക്കാന് നമുക്കൊരു ഫോള്ഡര് (ഡയറക്ടറി) ഉണ്ടാക്കാം. ഒരിക്കലെഴുതിയ പ്രോഗ്രാമുകള് പിന്നീടെപ്പോഴെങ്കിലും എടുത്തുനോക്കാനും മറ്റും ഇത് ഉപകാരപ്പെടും. ഈ ഡയറക്ടറിക്ക് ഇഷ്ടമുള്ള (പിന്നീട് ഓര്ക്കാന് എളുപ്പമുള്ള) എന്തു പേരുവേണമെങ്കിലും ഇടാം. MyPrograms എന്നാണ് ഞാനിട്ട പേര്. ഈ ഡയറക്ടറി എവിടെയാണെന്നതും ഓര്ത്തുവയ്ക്കുക. Home അഥവാ Desktop എന്നിവിടങ്ങളിലാണെങ്കില് ഓര്ക്കാന് എളുപ്പമുണ്ട് : എവിടെവേണമെങ്കിലും ആകാം.രണ്ടു വഴികള്
സ്കൂള് ലിനക്സ് കംപ്യൂട്ടറുകളില് ഈ ഡയറക്ടറി ഉണ്ടാക്കാനുള്ള രണ്ടു വഴികള് ഇനി പറയാം. രണ്ടിനും ഫലം ഒന്നുതന്നെ. ആദ്യത്തെ വഴിയാണ് കൂടുതല് എളുപ്പം. രണ്ടാമത്തേതിനാണ് കൂടുതല് ശക്തിയും മഹത്വവും (more general and powerful എന്നതിന്റെ സ്വതന്ത്ര പരിഭാഷ). വിശന്നിരിക്കുന്ന (നോണ്വെജിറ്റേറിയനായ) ഒരാള്ക്ക് ഒരു മീന് കൊടുക്കുന്നതും മീന് പിടിക്കാന് പഠിപ്പിച്ചുകൊടുക്കുന്നതും തമ്മിലുള്ള വ്യത്യാസം തന്നെ.ലിനക്സിലെ ഹോം ഡയറക്ടറി
ലിനക്സില് ഓരോ ആള്ക്കും (user) ഒരു Home Directory ഉണ്ട്. സാധാരണ ഈ ഡയറക്ടറിയുടെ പേര് /home/username എന്നായിരിക്കും. ഇവിടെ username എന്നുള്ളത് നാം ലിനക്സിലേക്ക് log in ചെയ്യാന് ഉപയോഗിക്കുന്ന പേരാണ്. എന്റെ കംപ്യൂട്ടറില് എന്റെ username gphilip എന്നായതുകൊണ്ട് എന്റെ Home Directory യുടെ പേര് /home/gphilip എന്നതാണ്.എളുപ്പവഴി
നമ്മുടെ Home Directory യില് MyPrograms എന്നപേരില് ഒരു ഡയറക്ടറി ഉണ്ടാക്കാനുള്ള എളുപ്പ വഴി:- File Browser-ല് Home Folder തുറക്കുക: Places -> Home Folder .
- അവിടെ File -> Create Folder എന്നത് തെരഞ്ഞെടുക്കുക.
- "untitled folder" എന്ന പേരില് ഒരു പുതിയ ഡയറക്ടറി ഉണ്ടായി വരും. ഇതില് right-click ചെയ്ത് "Rename..." എന്നത് തെരഞ്ഞെടുക്കുക. ഡയറക്ടറിക്കുള്ള പുതിയ പേരായി MyPrograms എന്നു കൊടുത്ത് Enter അമര്ത്തുക.
ടെര്മിനല് ഉപയോഗിച്ച്
ഇതേ ഡയറക്ടറി ടെര്മിനല് ഉപയോഗിച്ച് ഉണ്ടാക്കുന്ന വിധം:- ടെര്മിനല് തുറക്കുക: Applications -> Accessories -> Terminal.
- ടെര്മിനലില് ഒരു ഡോളര് ചിഹ്നവും (
)അതിനുതൊട്ടുവലതുവശത്തായിമിന്നുന്ന(blinking)ഒരുസൂചകവുംകാണാം.ഈസൂചകത്തിന്cursorഎന്നാണ്പേര്. -ഉം cursor-ഉം ചേര്ന്നതിനെ "command prompt" അഥവാ (ചുരുക്കത്തില്) "prompt" എന്നു വിളിക്കുന്നു."ഇവിടെ കമാന്റ് എഴുതിത്തുടങ്ങിക്കോളൂ" എന്നാണ് prompt സൂചിപ്പിക്കുന്നത്. കമാന്റ് എഴുതി Enter അമര്ത്തുമ്പോള് ടെര്മിനല് കമാന്റിനെ പ്രവര്ത്തിപ്പിക്കും. ഇങ്ങനെ ഒരു കമാന്റ് ടെര്മിനലില് എഴുതി Enter അമര്ത്തുന്നതിന് "കമാന്റ് കൊടുക്കുക" എന്നു പറയുന്നു. - ടെര്മിനല് എപ്പോഴും ഏതെങ്കിലും ഒരു ഡയറക്ടറിയിലായിരിക്കും
നിലകൊള്ളുന്നത്. ഇതിനെ "current working directory" (ഇപ്പോഴുള്ള ഡയറക്ടറി)
എന്നു വിളിക്കുന്നു. ടെര്മിനല് തുറക്കുമ്പോള് അതു തുറന്നയാളുടെ (user)
ഹോം ഡയറക്ടറിയിലായിരിക്കും ആദ്യം ടെര്മിനല് നിലകൊള്ളുന്നത്. ഇപ്പോഴുള്ള
ഡയറക്ടറി ഏതെന്നറിയാന്
pwd
എന്ന കമാന്റ് കൊടുക്കുക (Print Working Directory. Public Works Department അല്ല!). അടുത്ത വരിയില് ഇപ്പോഴുള്ള ഡയറക്ടറിയുടെ പേരും (ഉദാ: /home/gphilip) അതിനടുത്ത വരിയില് അടുത്ത കമാന്റ് സ്വീകരിക്കാന് തയ്യാറായി prompt-ഉം വരുന്നതുകാണാം. - ഇപ്പോഴുള്ള ഡയറക്ടറിക്കുള്ളില് (ടെര്മിനല് ആദ്യമായി
തുറന്നതായതുകൊണ്ട് ഇത് നമ്മുടെ Home Directory ആണ്) MyPrograms എന്ന
പേരില് പുതിയ ഒരു ഡയറക്ടറി ഉണ്ടാക്കാന് നമുക്ക്
mkdir
എന്ന കമാന്റ് ഉപയോഗിക്കാം (Make Directory). പുതുതായുണ്ടാക്കേണ്ട ഡയറക്ടറിയുടെ പേരും കൂടെ ചേര്ത്ത്mkdir MyPrograms
എന്നാണ് കമാന്റ് കൊടുക്കേണ്ടത്. കമാന്റ് തെറ്റൊന്നുമില്ലാതെ പ്രവര്ത്തിച്ചാല് അടുത്തവരിയില് prompt തയ്യാറായി നില്ക്കുന്നതുകാണാം. കമാന്റ് പ്രവര്ത്തിപ്പിക്കുന്നതില് തെറ്റെന്തെങ്കിലും സംഭവിച്ചാല് അതിനെപ്പറ്റിയുളള സംക്ഷിപ്തമായ വിവരണത്തിനുശേഷം prompt വീണ്ടും കാണാം. ഇപ്പറഞ്ഞ സംക്ഷിപ്തമായ വിവരണം കാണാന് കൗതുകമുണ്ടെങ്കില് (ഉണ്ടെങ്കില് മാത്രം) താഴെപ്പറയുന്നവ ചെയ്തുനോക്കുക:
-
mkdir
കമാന്റിന് പുതുതായുണ്ടാക്കേണ്ട ഡയറക്ടറിയുടെ പേരു കൊടുക്കാതെയിരിക്കുക. അതായത്,mkdir
എന്നുമാത്രം കമാന്റ് കൊടുക്കുക. "പുതിയ ഡയറക്ടറിയുടെ പേര് എവിടെ?" എന്നര്ത്ഥം വരുന്ന ഒരു പരാതി കിട്ടുന്നതുകാണാം. - MyPrograms എന്ന ഡയറക്ടറി ഒരു പ്രാവശ്യം ഉണ്ടാക്കിയതിനുശേഷം വീണ്ടും
അതേപേരില് അതേ സ്ഥലത്ത് ഒരു ഡയറക്ടറികൂടെ ഉണ്ടാക്കാന് ശ്രമിക്കുക.
അതായത്,
mkdir MyPrograms
എന്ന കമാന്റ് വീണ്ടും കൊടുക്കുക. ടെര്മിനല് "സാധ്യമല്ല!" എന്ന് പറയുന്നത് കാണാം.
-
- മേല്പ്പറഞ്ഞ കമാന്റുപയോഗിച്ച് പുതുതായുണ്ടാക്കിയ ഡയറക്ടറി ശരിക്കും അവിടെയുണ്ടോ എന്നു കാണാന്
ls
എന്ന കമാന്റുപയോഗിക്കാം (ലിനക്സിന്റെ പൂര്വികരിലൊന്നായ മള്ട്ടിക്സ് (1964-2000) എന്ന ഒരു മുന്കാല ഓപ്പറേറ്റിങ്ങ് സിസ്റ്റത്തിലെ "list segments" എന്ന ഇതേ ആവശ്യത്തിനുള്ള കമാന്റിന്റെ ചുരുക്കപ്പേരില് നിന്നാണ് ഈ പേര് വന്നത്.).ls
എന്ന കമാന്റ് കൊടുക്കുക. ഹോം ഡയറക്ടറിയിലുള്ള ഫയലുകളുടെയും ഡയറക്ടറികളുടെയും ഒരു ലിസ്റ്റ് ഉത്തരമായി കാണാം; അക്കൂട്ടത്തില് MyPrograms എന്ന പുതിയ ഡയറക്ടറിയെയും.
പ്രോഗ്രാം എഴുതി സേവ് ചെയ്യുക
ഇനി നമുക്ക് നമ്മുടെ ആദ്യത്തെ പൈത്തണ് പ്രോഗ്രാം എഴുതി പുതുതായുണ്ടാക്കിയ MyPrograms ഡയറക്ടറിയില് സേവ് ചെയ്യാം.- gedit തുറക്കുക (Applications -> Accessories -> Text Editor).
- പുതിയ ഒരു ഫയലില് താഴെപ്പറയുന്നവ എഴുതുക (കോപ്പി-പേസ്റ്റ് ചെയ്താലും മതി). ഇതാണ് നമ്മുടെ (അതിലളിതമായ) ആദ്യത്തെ പൈത്തണ് പ്രോഗ്രാം :
- ഈ ഫയലിനെ hello.py എന്നപേരില് മുന്പുണ്ടാക്കിയ ഡയറക്ടറിയില് സേവ് ചെയ്യുക. ഇതിനായി gedit-ല് File -> Save തെരഞ്ഞെടുത്ത് MyPrograms എന്ന ഡയറക്ടറിയുടെമേല് double-click ചെയ്യുക. Name: എന്ന് കാണുന്ന വരിയില് hello.py എന്നുകൊടുത്ത് Save എന്ന ബട്ടണ് അമര്ത്തുക. ഫയലിന്റെ പേരെന്തായാലും കുഴപ്പമില്ല, .py എന്നവസാനിക്കണമെന്നേയുള്ളൂ -- കുത്ത് പ്രത്യേകം ശ്രദ്ധിക്കുക! നമ്മുടെ പ്രോഗ്രാം സേവ് ചെയ്തുകഴിഞ്ഞ gedit കണ്ടാല് ഏകദേശം ഇങ്ങനെയിരിക്കും.
# The first program that learners write in any language is, by # convention, a program that outputs "Hello, World!". So here is # our first program in Python. print "Hello, World!" # Coming next: A Malayalam version of this program!
1
2
3
4
5
6
7
| # The first program that learners write in any language is, by # convention, a program that outputs "Hello, World!". So here is # our first program in Python. print "Hello, World!" # Coming next: A Malayalam version of this program! |
പ്രോഗ്രാം പ്രവര്ത്തിപ്പിക്കാന്
നാമെഴുതി hello.py എന്ന പേരില് സേവ് ചെയ്ത പ്രോഗ്രാം പ്രവര്ത്തിപ്പിച്ച് അതിന്റെ ഫലം (output) കാണാന് നമുക്ക് ടെര്മിനല് ഉപയോഗിക്കാം. ആദ്യമായി ചെയ്യേണ്ടത് ഈ പ്രോഗ്രാം സൂക്ഷിച്ചിരിക്കുന്ന ഡയറക്ടറിയില് ടെര്മിനല് ഉപയോഗിച്ച് എത്തിപ്പറ്റുക എന്നതാണ്. ഇതിന് താഴെപ്പറയുന്നവയില് ഒന്ന് ചെയ്യുക:
- എളുപ്പ(?) വഴി
- File Browser-ല് Home Folder തുറക്കുക: Places -> Home Folder .
- തുറന്നുവരുന്ന ഫയലുകളുടെയും ഡയറക്ടറികളുടെയും ലിസ്റ്റില് MyPrograms എന്ന ഡയറക്ടറിയുടെ പേരുള്ള ചിത്രത്തില് (icon) right-click ചെയ്യുക. തെളിഞ്ഞുവരുന്ന പുതിയ ലിസ്റ്റില് "Open in Terminal" എന്നത് തെരഞ്ഞെടുക്കുക. MyPrograms എന്ന ഡയറക്ടറിയില് കമാന്റുകള് കൊടുക്കാന് സജ്ജമായി ഒരു ടെര്മിനല് തുറന്നുവരുന്നതു കാണാം.
- ടെര്മിനല് ഉപയോഗിച്ച്
- മുമ്പു തുറന്ന ടെര്മിനലില് ചെല്ലുക (പുതിയ ടെര്മിനല് തുറന്നാലും മതി).
- ഹോം ഡയറക്ടറിയിലേക്ക് മാറുക. ഇതിനായി
cd
എന്ന കമാന്റ് കൊടുക്കുക (Change Directory). ടെര്മിനല് നിലകൊള്ളുന്ന ഡയറക്ടറി എന്തുതന്നെ ആയാലുംcd
എന്ന കമാന്റിനു ശേഷം അത് ഹോം ഡയറക്ടറിയിലേക്ക് മാറും. - ഹോം ഡയറക്ടറിക്കുള്ളിലെ MyPrograms ഡയറക്ടറിയിലേക്ക് മാറുക. ഇതിനായി
cd
എന്ന കമാന്റ് തന്നെ ഉപയോഗിക്കാം. ഹോം ഡയറക്ടറിയല്ലാത്ത ഒരു ഡയറക്ടറിയിലേക്ക് മാറാന്വേണ്ടിയായതുകൊണ്ട് കമാന്റിന് ഡയറക്ടറിയുടെ പേരും പറഞ്ഞുകൊടുക്കണം. അതായത്,cd MyPrograms
എന്നാണ് കമാന്റ് കൊടുക്കേണ്ടത്. ഈ കമാന്റിനുശേഷം ടെര്മിനല് MyPrograms എന്ന ഡയറക്ടറിയിലായിരിക്കും. - (ബോണസ്) നാം എഴുതി സേവ് ചെയ്ത hello.py എന്ന ഫയല് ഈ ഡയറക്ടറിയില് ഉണ്ടെന്ന് കാണാന്
ls
എന്ന കമാന്റ് കൊടുക്കുക.
python hello.py
പ്രോഗ്രാം എഴുതിയതില് തെറ്റൊന്നും വന്നിട്ടില്ലെങ്കില് ഒരു പുതിയ വരിയില്Hello, World!
എന്നു വരുന്നതു കാണാം. ഇതാണ് ഈ ലളിതമായ പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനഫലം (output). ഇനി ഇതല്ല മറ്റെന്തെങ്കിലുമാണ് കാണുന്നതെങ്കില് അത് രണ്ടുകാര്യം കൊണ്ടാകാം:
- സിസ്റ്റത്തില് python ഇന്സ്റ്റാള് ചെയ്തിട്ടില്ല. സ്കൂള് സിസ്റ്റമാണെങ്കില് ഇതാവില്ല കാരണം, മറിച്ച്:
- പ്രോഗ്രാം എടുത്തെഴുതിയതില് എവിടെയോ പിഴവു പറ്റി. ഇതെവിടെയാണെന്ന് മനസ്സിലാക്കി തിരുത്തുക.
ഈ പ്രോഗ്രാമിന്റെ സമഗ്രമായ വിശദീകരണവും, ഇതിന്റെതന്നെ മലയാളം പതിപ്പും, മറ്റുകാര്യങ്ങളും അടുത്ത പാഠത്തില്. മേല്പ്പറഞ്ഞ കാര്യങ്ങള് ചെയ്തുനോക്കി, പറഞ്ഞതുപോലെയൊക്കെ സംഭവിച്ചെങ്കില് അതും, അതല്ല പ്രശ്നങ്ങള് ഉണ്ടായെങ്കില് അതും കമന്റായിടുക; കൂടെ മറ്റു സംശയങ്ങളും ചോദ്യങ്ങളും നിര്ദ്ദേശങ്ങളും.
തയ്യാറാക്കാന് സഹായിച്ചവര്: നിസാര് വി കെ, ഹസൈനാര് മങ്കട, ശ്രീനാഥ് എച്ച്, ഹരികുമാര് കെ ജി, ഹോംസ്.
നമ്മുടെ കംപ്യൂട്ടറില് സൂക്ഷിച്ചുവെക്കാനും മറ്റുള്ളവര്ക്ക് പകര്ത്തി കൊടുക്കാനും പാകത്തില് ഈ പാഠത്തിന്റെ പി.ഡി.എഫ് പതിപ്പ് ഇവിടെ.
പൈത്തണ്: പാഠം രണ്ട്
>> Wednesday, June 16, 2010
കംപ്യൂട്ടറില് സംഭവിക്കുന്നതെന്തെന്നാല് ...
നമ്മുടെ മാതൃഭാഷ മലയാളമാണെന്നതുപോലെ കംപ്യൂട്ടറിന്റെ "മാതൃഭാഷ" Machine Language (യന്ത്രഭാഷ) എന്ന പേരുള്ള, 0,1 എന്നീ രണ്ട് "അക്ഷരങ്ങള്" മാത്രമുപയോഗിച്ചെഴുതുന്ന ഒരുതരം ഭാഷയാണ്. ഈ ഭാഷ പഠിച്ച് അതുപയോഗിച്ച് കംപ്യൂട്ടറിന് നിര്ദ്ദേശങ്ങള് കൊടുക്കുക എന്നത് സാധ്യമാണെങ്കിലും ദുഷ്കരമാണ്. പൈത്തണ് പോലെയുള്ള, ഒരു മനുഷ്യഭാഷയോട് (അതായത്, ഇംഗ്ളീഷിനോട്) കുറച്ചൊക്കെ സാമ്യമുള്ള ഭാഷകള് ഉപയോഗിച്ച് പ്രോഗ്രാമുകള് എഴുതുക എന്നത് ഇതിനെ അപേക്ഷിച്ച് വളരെ സുകരമാണ്.
നമ്മുടെ പൈത്തണ് പ്രോഗ്രാം വായിച്ചുനോക്കി നാം എഴുതിയ പൈത്തണ് ഭാഷയില് തെറ്റുകളെന്തെങ്കിലുമുണ്ടെങ്കില് അതു പറയുകയും, തെറ്റുകളൊന്നുമില്ലെങ്കില് പ്രോഗ്രാമില് നിര്ദ്ദേശിച്ചിരിക്കുന്ന കാര്യങ്ങള് നടപ്പിലാക്കുകയും ചെയ്യുന്നത് പൈത്തണ് ഇന്റര്പ്രെറ്റര് (Python Interpreter) എന്നു വിളിക്കപ്പെടുന്ന, അനേകം ആളുകള് ചേര്ന്ന് എഴുതിയുണ്ടാക്കിയ ഒരു പ്രോഗ്രാമാണ്. Interpreter എന്ന വാക്കിന് "അര്ത്ഥം വിശദമാക്കുന്നയാള്", "ദ്വിഭാഷി" എന്നൊക്കെ അര്ത്ഥം പറയാം (ഉദാ:- An interpreter of dreams, French interpreter). നാം പൈത്തണ് ഭാഷയിലെഴുതിയ പ്രോഗ്രാമിനെ കംപ്യൂട്ടറിനു മനസ്സിലാകുന്ന യന്ത്രഭാഷയിലേക്ക് മൊഴിമാറ്റം ചെയ്യുക എന്നതാണല്ലോ പൈത്തണ് ഇന്റര്പ്രെറ്റര് ചെയ്യുന്നത്? അതുകൊണ്ട് പൈത്തണ് ഇന്റര്പ്രെറ്റര് അഥവാ പൈത്തണ് ദ്വിഭാഷി എന്ന പേര് ഈ പ്രോഗ്രാമിന് തികച്ചും ചേര്ന്നത് തന്നെ.
ലിനക്സില് പൈത്തണ് ഇന്റര്പ്രെറ്ററുടെ പേര് python എന്നാണ്. നാം കഴിഞ്ഞ പാഠത്തില് ഉപയോഗിച്ച
python hello.py
എന്ന കമാന്റ് ചെയ്യുന്നത്, ഈ ഇന്റര്പ്രെറ്ററിന് നാമെഴുതിയ hello.py എന്ന്
പ്രോഗ്രാം ഇന്പുട്ട് ആയി കൊടുക്കുക എന്നതാണ്. python (ഇന്റര്പ്രെറ്റര്)
ആകട്ടെ, hello.py എന്ന ഈ പ്രോഗ്രാം വായിച്ച് അതില് പറഞ്ഞ കാര്യങ്ങള്
ചെയ്യുന്നു. പൈത്തണ് ഭാഷയിലെഴുതിയ ഒരു പ്രോഗ്രാം
പ്രവര്ത്തിപ്പിക്കുമ്പോള് സംഭവിക്കുന്നത്, ചുരുക്കത്തില് പറഞ്ഞാല്
ഇത്രയുമൊക്കെയാണ്. ഇനിയുള്ള പാഠങ്ങളില് പൈത്തണ് ഭാഷ, പൈത്തണ് ഇന്റര്പ്രെറ്റര് എന്നീ രണ്ടുകാര്യങ്ങളേയും "പൈത്തണ്" എന്ന ഒറ്റ വാക്ക് ഉപയോഗിച്ചാവും സൂചിപ്പിക്കുക. എഴുതാനും വായിക്കാനും ഇതാണ് എളുപ്പം; അര്ത്ഥശങ്ക ഉണ്ടാവാന് തീരെ സാധ്യതയില്ലതാനും.
ആദ്യപ്രോഗ്രാം: വിശദമായ വായന.
കഴിഞ്ഞ പാഠത്തില് കണ്ട ചെറിയ പൈത്തണ് പ്രോഗ്രാം വിജയകരമായി പ്രവര്ത്തിപ്പിച്ചുനോക്കിക്കാണുമല്ലോ. ഇപ്പോള് നമുക്ക് ഇതിന്റെ ഭാഗങ്ങള് അടയാളപ്പെടുത്തി വിശദീകരിക്കാം.പ്രോഗ്രാം ഇവിടെ എടുത്തെഴുതുന്നു:
1
2
3
4
5
6
7
| # The first program that learners write in any language is, # by convention, a program that outputs "Hello, World!". So # here is our first program in Python. print "Hello, World!" # Coming next: A Malayalam version of this program! |
ഈ പ്രോഗ്രാമില് മൂന്നുതരം വരികളാണുള്ളത്:
- # എന്ന ചിഹ്നം തുടക്കത്തില് വരുന്ന വരികള് പൈത്തണില് # എന്ന ചിഹ്നം കമന്റുകളെ വേറിട്ടുകാണിക്കാന് ഉപയോഗിക്കുന്ന മാര്ഗ്ഗമാണ്. പ്രോഗ്രാം വായിയ്ക്കുന്ന മറ്റു മനുഷ്യര്ക്കുവേണ്ടി പ്രോഗ്രാം എഴുതുന്നയാള് ഉള്പ്പെടുത്തുന്ന കുറിപ്പുകളെയാണ് കമന്റ് എന്നു പറയുന്നത് . # എന്ന ചിഹ്നം കണ്ടാല് പിന്നെ ആ വരിയില് ബാക്കിയുള്ള കാര്യങ്ങളെ പൈത്തണ് അവഗണിക്കും. അതായത്, "ഈ വരിയില് ഇനിയുള്ള കാര്യങ്ങള് അവഗണിച്ചോളൂ" എന്ന് പൈത്തണോട് പറയാനുള്ള ഉപാധിയാണ് # എന്ന ചിഹ്നം. കമന്റുകളുടെ പ്രാധാന്യത്തെപ്പറ്റി വഴിയേ പറയാം.
- ശൂന്യമായ വരികള് ഒരക്ഷരവും ഇല്ലാത്ത വരികളുടെ പ്രോഗ്രാമിലെ ഉപയോഗം സാധാരണ എഴുത്തുഭാഷയിലെ ഉപയോഗം പോലെതന്നെയാണ്: വായനക്കാരന്റെ കണ്ണുകളുടെ ആയാസം കുറയ്ക്കലും, പുതിയ ഒരു കാര്യം പറഞ്ഞുതുടങ്ങുമ്പോള് അതിനെ മുമ്പുപറഞ്ഞതില്നിന്ന് വേറിട്ടുകാണിക്കലും. ഈ രണ്ടുകാര്യങ്ങളും പൈത്തണ് ഇന്റര്പ്രെറ്റര്ക്കു പ്രധാനമല്ലാത്തതുകൊണ്ട്, ഇങ്ങനെയുള്ള വരികളെ പൈത്തണ് അവഗണിക്കുന്നു. ചുരുക്കത്തില്: ഒരക്ഷരവും ഇല്ലാത്ത ശൂന്യമായ ഒരു വരി കണ്ടാല് പൈത്തണ് ആ വരിയെ അവഗണിക്കുന്നു.
- print എന്ന വാക്കില് തുടങ്ങുന്ന വരി ഈ പ്രോഗ്രാമില് പൈത്തണ് ഭാഷയിലുള്ള ഒരേ ഒരു വരി ഇതാണെന്ന് പറയാം; മറ്റുള്ളതൊക്കെ ഇംഗ്ളീഷ് തന്നെയാണല്ലോ? print എന്നുള്ളത് പ്രോഗ്രാമിന്റെ output --- പുറത്തുകാണേണ്ട പ്രവര്ത്തനഫലം --- പുറത്തുകാണിക്കാന് ഉപയോഗിക്കുന്ന ഒരു പൈത്തണ് കീവേഡ് (keyword) ആണ്. പൈത്തണില് ഇരുപതോളം വാക്കുകളെ ഇങ്ങനെ keyword അഥവാ പ്രധാനവാക്ക് /പ്രത്യേകവാക്ക് എന്ന് പേരിട്ട് വേര്തിരിച്ചിട്ടുണ്ട്. പ്രോഗ്രാമുകളില് ചില പ്രത്യേക ആവശ്യങ്ങള്ക്കായി ഉപയോഗിക്കുന്നതുകൊണ്ടാണ് ഇവയെ കീവേഡ് എന്നു വിളിക്കുന്നത്. ഇവയില് മിക്കതിനേയും നമുക്ക് വഴിയേ പരിചയപ്പെടാം. print എന്ന കീവേഡ് ചെയ്യുന്നത്, തനിക്കുശേഷം അതേ വരിയില് കാണുന്ന കാര്യങ്ങളെ ഔട്ട്പുട്ട് ചെയ്യുക എന്നതാണ്. print ഇങ്ങനെ ചെയ്തതാണ് നാം പ്രോഗ്രാമിന്റെ ഔട്ട്പുട്ട് ആയി കണ്ടത്.
പൈത്തണ് പ്രോഗ്രാമുകള് എഴുതാന് കീവേഡുകള് ഏതൊക്കെ എന്നത് കാണാതെ പഠിക്കേണ്ട കാര്യമൊന്നുമില്ല. print എന്നത് കീവേഡ് ആണോ മറ്റെന്തെങ്കിലും ആണോ എന്ന് എനിക്ക് ഉറപ്പൊന്നുമില്ലായിരുന്നു. ഈ പാഠം എഴുതാനിരുന്നപ്പോള് വായിച്ചു നോക്കി കണ്ടുപിടിച്ചതാണ്.
പ്രോഗ്രാമിന്റെ മലയാളം പതിപ്പ്
മുകളില്ക്കൊടുത്ത പ്രോഗ്രാമിന്റെ മലയാളത്തിലുള്ള പതിപ്പാണ് താഴെയുള്ളത്. ഇത് പ്രവര്ത്തിപ്പിക്കാന് മുമ്പുചെയ്തതുപോലെ gedit-ല് ഒരു പുതിയ ഫയല് തുറന്ന്, പ്രോഗ്രാം അതിലേക്ക് പകര്ത്തി, ml_helloworld.py എന്ന പേരില് സേവ് ചെയ്യുക. മുമ്പുപറഞ്ഞതുപോലെ ഈ പേര് എന്തുവേണമെങ്കിലുമാകാം, .py എന്ന് അവസാനിക്കണമെന്നേയുള്ളൂ. ഒരു കാര്യം പ്രത്യേകം ശ്രദ്ധിക്കേണ്ടത്, ഫയലിന്റെ ആദ്യത്തെ വരിയില്ത്തന്നെ "...coding..." എന്നത് വരണം എന്നുള്ളതാണ്. പ്രോഗ്രാം പ്രവര്ത്തിപ്പിക്കുന്നവിധവും നേരത്തേതുപോലെതന്നെ: പ്രോഗ്രാം സേവ് ചെയ്തിരിക്കുന്ന ഡയറക്ടറിയില് ടെര്മിനല് ഉപയോഗിച്ച്python ml_helloworld.py
എന്ന കമാന്റ് കൊടുക്കുക. ഈ പ്രോഗ്രാമിനെപ്പറ്റിയുള്ള വിവരണം കമന്റുകളായി പ്രോഗ്രാമില്ത്തന്നെ ചേര്ത്തിട്ടുണ്ട്. # coding=utf-8 # (ഹാവൂ! ഇനി മലയാളത്തില് കമന്റുകള് എഴുതാം!) # ഏറ്റവും മുകളില്ക്കാണുന്ന കോഡ് (coding എന്നുംമറ്റുമുള്ള ലൈന്) # ഇംഗ്ളീഷിതര അക്ഷരങ്ങള് പ്രോഗ്രാമില് ഉള്പ്പെടുത്താന് വേണ്ടിയുള്ളതാണ്. ഈ # പ്രോഗ്രാമില് കമെന്റിലും പിന്നെ പ്രോഗ്രാമില് ഒരിടത്തും മലയാള # അക്ഷരങ്ങള് ഉപയോഗിക്കാന്വേണ്ടിയാണ് ആ ലൈന് ചേര്ത്തത്. # പൈത്തണ് ഭാഷയില് പ്രത്യേക ആവശ്യങ്ങള്ക്കായി ഉപയോഗിക്കുന്ന, keyword # (കീവേഡ്: പ്രത്യേകവാക്ക്/പ്രധാനവാക്ക്) എന്ന് വിളിക്കുന്ന ഇരുപതോളം # വാക്കുകളുണ്ട്. അടുത്ത കാലത്തിറങ്ങിയ പൈത്തണ് മൂന്നാം പതിപ്പില് ഈ # പ്രത്യേകവാക്കുകള് ഒഴികെ മറ്റെല്ലാം മലയാളത്തിലോ മറ്റു ഭാഷകളിലോ # എഴുതാം; പ്രത്യേകവാക്കുകള് ഇംഗ്ളീഷ് അക്ഷരങ്ങള് ഉപയോഗിച്ചു മാത്രമേ # എഴുതാന് കഴിയൂ. # നാം പഠനത്തിനായി തെരഞ്ഞെടുത്ത പൈത്തണ് രണ്ടാം പതിപ്പില് പക്ഷേ # മലയാളത്തിന്റെ ഉപയോഗം ഒരു കൗതുകം മാത്രമായേ കാണാന് പറ്റൂ: # പ്രോഗ്രാമില് ഒരേ ഒരു തരം കാര്യം (ഇതിന്റെ ഒരുദാഹരണം താഴത്തെ # പ്രോഗ്രാമില് ഉണ്ട്) ഒഴികെ ബാക്കിയെല്ലാം ഇംഗ്ളീഷ് അക്ഷരങ്ങള് ഉപയോഗിച്ചേ # ഈ പതിപ്പില് എഴുതാവൂ. കമന്റുകളും ഇംഗ്ളീഷില്ത്തന്നെ എഴുതുന്നതാണ് # നിലവിലുള്ള രീതി. കമന്റുകള് മറ്റു മനുഷ്യര്ക്കു വായിക്കുവാന്വേണ്ടി # മാത്രമുള്ളതായതുകൊണ്ട്, അതെഴുതുമ്പോള് വ്യാകരണത്തെറ്റോ മറ്റോ # വന്നാലും പ്രോഗ്രാം ഭംഗിയായി ഓടിക്കൊള്ളൂം. # കമന്റ് എന്നു പറയുന്നത് ദാ ഇതുപോലെ "#" എന്നുതുടങ്ങുന്ന ലൈനുകളാണ്. ഇവ # മറ്റു മനുഷ്യര്ക്ക് വായിക്കുവാന്വേണ്ടി ഉള്ളതാണ്: പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനത്തെ # ഇവ ഒരുവിധത്തിലും ബാധിക്കുന്നില്ല. # ഇനി പ്രോഗ്രാമിലേക്ക് : പ്രോഗ്രാമിംഗ് പഠിക്കുമ്പോള് സാധാരണ ആദ്യം # എഴുതാറുള്ള "Hello, World!" പ്രോഗ്രാമിന്റെ മലയാള "ഭാഷ്യം": print "സ്വാഗതം!"
ഈസ്റ്റ്മാന് കളറില്:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
| # coding=utf-8 # (ഹാവൂ! ഇനി മലയാളത്തില് കമന്റുകള് എഴുതാം!) # ഏറ്റവും മുകളില്ക്കാണുന്ന കോഡ് (coding എന്നുംമറ്റുമുള്ള ലൈന്) # ഇംഗ്ളീഷിതര അക്ഷരങ്ങള് പ്രോഗ്രാമില് ഉള്പ്പെടുത്താന് വേണ്ടിയുള്ളതാണ്. ഈ # പ്രോഗ്രാമില് കമെന്റിലും പിന്നെ പ്രോഗ്രാമില് ഒരിടത്തും മലയാള # അക്ഷരങ്ങള് ഉപയോഗിക്കാന്വേണ്ടിയാണ് ആ ലൈന് ചേര്ത്തത്. # പൈത്തണ് ഭാഷയില് പ്രത്യേക ആവശ്യങ്ങള്ക്കായി ഉപയോഗിക്കുന്ന, keyword # (കീവേഡ്: പ്രത്യേകവാക്ക്/പ്രധാനവാക്ക്) എന്ന് വിളിക്കുന്ന ഇരുപതോളം # വാക്കുകളുണ്ട്. അടുത്ത കാലത്തിറങ്ങിയ പൈത്തണ് മൂന്നാം പതിപ്പില് ഈ # പ്രത്യേകവാക്കുകള് ഒഴികെ മറ്റെല്ലാം മലയാളത്തിലോ മറ്റു ഭാഷകളിലോ # എഴുതാം; പ്രത്യേകവാക്കുകള് ഇംഗ്ളീഷ് അക്ഷരങ്ങള് ഉപയോഗിച്ചു മാത്രമേ # എഴുതാന് കഴിയൂ. # നാം പഠനത്തിനായി തെരഞ്ഞെടുത്ത പൈത്തണ് രണ്ടാം പതിപ്പില് പക്ഷേ # മലയാളത്തിന്റെ ഉപയോഗം ഒരു കൗതുകം മാത്രമായേ കാണാന് പറ്റൂ: # പ്രോഗ്രാമില് ഒരേ ഒരു തരം കാര്യം (ഇതിന്റെ ഒരുദാഹരണം താഴത്തെ # പ്രോഗ്രാമില് ഉണ്ട്) ഒഴികെ ബാക്കിയെല്ലാം ഇംഗ്ളീഷ് അക്ഷരങ്ങള് ഉപയോഗിച്ചേ # ഈ പതിപ്പില് എഴുതാവൂ. കമന്റുകളും ഇംഗ്ളീഷില്ത്തന്നെ എഴുതുന്നതാണ് # നിലവിലുള്ള രീതി. കമന്റുകള് മറ്റു മനുഷ്യര്ക്കു വായിക്കുവാന്വേണ്ടി # മാത്രമുള്ളതായതുകൊണ്ട്, അതെഴുതുമ്പോള് വ്യാകരണത്തെറ്റോ മറ്റോ # വന്നാലും പ്രോഗ്രാം ഭംഗിയായി ഓടിക്കൊള്ളൂം. # കമന്റ് എന്നു പറയുന്നത് ദാ ഇതുപോലെ "#" എന്നുതുടങ്ങുന്ന ലൈനുകളാണ്. ഇവ # മറ്റു മനുഷ്യര്ക്ക് വായിക്കുവാന്വേണ്ടി ഉള്ളതാണ്: പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനത്തെ # ഇവ ഒരുവിധത്തിലും ബാധിക്കുന്നില്ല. # ഇനി പ്രോഗ്രാമിലേക്ക് : പ്രോഗ്രാമിംഗ് പഠിക്കുമ്പോള് സാധാരണ ആദ്യം # എഴുതാറുള്ള "Hello, World!" പ്രോഗ്രാമിന്റെ മലയാള "ഭാഷ്യം": print "സ്വാഗതം!" |
പ്രോഗ്രാം കോപ്പി ചെയ്യാനുള്ള എളുപ്പവഴി: മൗസ് സൂചിക പ്രോഗ്രാമിന്റെ ആദ്യത്തെ വരിയില് കൊണ്ടു പോകുക (പ്രോഗ്രാമില് എവിടെയാണെങ്കിലും മതി). ഒരു പ്രിന്ററിന്റെ ചിത്രം ഉള്പ്പടെ നാലു ചെറിയ ചിത്രങ്ങള് (icons) ഉള്ള ഒരു ചതുരം പ്രോഗ്രാമിന്റെ മുകളിലായി പ്രത്യക്ഷപ്പെടുന്നതുകാണാം. ഇതില് രണ്ടാമത്തെ ചിത്രത്തില് (രണ്ടു കടലാസുകള് ഒന്നിനുമീതെ ഒന്നായി വച്ചിരിക്കുന്നതിന്റെ ചിത്രം) അമര്ത്തുക. പ്രോഗ്രാമിന്റെ ശുദ്ധരൂപം (ലൈന് നമ്പറുകളും വര്ണ്ണങ്ങളും മറ്റുമില്ലാത്തത്) കോപ്പി ചെയ്തു കഴിഞ്ഞു. ഇനി എഡിറ്ററില് (ഉദാ: gedit) ഇതു പേസ്റ്റു ചെയ്യാം. പേസ്റ്റു ചെയ്തു നോക്കൂ! ഇതേപോലെ കാണുന്ന ഏതു പ്രോഗ്രാമും ഈ രീതിയില് കോപ്പി ചെയ്യാം.
ഈ പ്രോഗ്രാമില് കമന്റുകളിലല്ലാതെ മലയാളം വരുന്നത് print എന്നതിനുശേഷം വരുന്ന "സ്വാഗതം!" എന്ന string-ല് മാത്രമാണല്ലോ. നാം പഠനത്തിനായി തെരഞ്ഞെടുത്ത പൈത്തണ് രണ്ടാം പതിപ്പില് ഈ രണ്ടിടങ്ങളില് മാത്രമേ ഇംഗ്ലീഷിതര അക്ഷരങ്ങള് പ്രോഗ്രാമില് ഉപയോഗിക്കാന് പറ്റൂ. ഏറ്റവും പുതിയതായ മൂന്നാം പതിപ്പില് പ്രധാനവാക്കുകള് ഒഴികെയുള്ളത് മലയാളത്തില് (മറ്റു ഭാഷകളിലും) എഴുതാം. മുകളില് മലയാളത്തില് പ്രോഗ്രാമെഴുതിയത് ഒരു കൗതുകത്തിന് മാത്രം. മുമ്പോട്ടുള്ള പാഠങ്ങളിലെ പ്രോഗ്രാമുകള് ഇംഗ്ളീഷില്ത്തന്നെ ആയിരിക്കും എഴുതുക: താത്പര്യമുള്ളവര്ക്ക് പ്രോഗ്രാമിനെ മലയാളീകരിക്കാനുള്ള വിദ്യ മനസ്സിലായല്ലോ.
കൂട്ടലും കുറയ്ക്കലും (മറ്റു ക്രിയകളും)
പൈത്തണ് ഉപയോഗിച്ച് ഗണിതക്രിയകള് ചെയ്യുന്നതെങ്ങനെ എന്നു നോക്കാം. കൂട്ടല്, കുറയ്ക്കല് എന്നിവയ്ക്ക് നാം സാധാരണ ഉപയോഗിച്ചുവരുന്ന +, - എന്നീ ചിഹ്നങ്ങളാണ് പൈത്തണിലും ഉപയോഗിക്കുന്നത്. ഗുണനത്തിന് പക്ഷേ x അല്ല, * ആണ് ഉപയോഗിക്കേണ്ടത്. ഹരണത്തിന് / ഉം ഘാതത്തിന് (കൃതിക്ക്) ** ഉം ശിഷ്ടം കാണാന് % ഉമാണ് ചിഹ്നങ്ങള്. ക്രിയകള് ചെയ്യേണ്ടുന്ന ക്രമം വ്യക്തമാക്കാന് (വായിച്ചു മനസ്സിലാക്കാനുള്ള എളുപ്പത്തിനും) ഒരേ ഒരുതരം ബ്രായ്ക്കറ്റേ ഉപയോഗിക്കാവൂ: () മാത്രം. ഈ ആവശ്യത്തിന് നാം സാധാരണ ഉപയോഗിക്കുന്ന {}, [] എന്നീ തരം ബ്രായ്ക്കറ്റുകള്ക്ക് പൈത്തണില് മറ്റ് അര്ത്ഥങ്ങളുള്ളതുകൊണ്ട് ഇവ ഗണിതക്രിയകളില് ഈ ആവശ്യത്തിന് ഉപയോഗിച്ചുകൂടാ.
പ്രോഗ്രാമില് ഗണിതക്രിയകള് ചെയ്യുന്നതെങ്ങനെ എന്നുകാണാന് താഴെയുള്ള പ്രോഗ്രാം നോക്കുക. വായിക്കുന്നയാളെ സഹായിക്കാനായി പ്രോഗ്രാമില് യഥേഷ്ടം കമന്റുകള് കൊടുത്തിരിക്കുന്നത് ശ്രദ്ധിക്കുക; പ്രോഗ്രാം വ്യക്തമായി മനസ്സിലാക്കാന് സഹായിക്കുന്ന കമന്റുകള് നല്ല പ്രോഗ്രാമിന്റെ ലക്ഷണമാണ്.
# We can do simple numerical calculations easily with # Python. # # Use: # + for addition # - for subtraction # * for multiplication # / for division # ** for exponentiation # % for remainder after division # Examples: print 5 + 3 print 5 - 3 print 5 * 3 print 5 / 2 # Since the operands are integers, the result # is also an integer print 5 ** 3 print 5 % 3 # We can make the output easier to understand by printing # out the expression along with the result. Here is how to # use the comma (,) to do this: print "5 + 3 = ", 5 + 3 print "5 ** 3 = ", 5 ** 3 # To get fractional values in the result, include a decimal # point in at least one operand: print "5 / 2 = ", 5.0 / 2 print "5 / 3 = ", 5 / 3.0 print "Here is one approximation to Pi: ", 22.0/7 print "And here is a better approximation : ", 355/113.0 # We can do more complicated calculations as well. Notice # how a long line is split across two lines using the # backslash ( \ ): print "Here is a big negative integer: ",\ (17 ** 21 + 5)*(36 % 11 + 76 * 43)-(712 + 5243 ** 32) # Try doing different calculations and see what you get!
കളര് പതിപ്പ്:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
| # We can do simple numerical calculations easily with # Python. # # Use: # + for addition # - for subtraction # * for multiplication # / for division # ** for exponentiation # % for remainder after division # Examples: print 5 + 3 print 5 - 3 print 5 * 3 print 5 / 2 # Since the operands are integers, the result # is also an integer print 5 * * 3 print 5 % 3 # We can make the output easier to understand by printing # out the expression along with the result. Here is how to # use the comma (,) to do this: print "5 + 3 = " , 5 + 3 print "5 ** 3 = " , 5 * * 3 # To get fractional values in the result, include a decimal # point in at least one operand: print "5 / 2 = " , 5.0 / 2 print "5 / 3 = " , 5 / 3.0 print "Here is one approximation to Pi: " , 22.0 / 7 print "And here is a better approximation : " , 355 / 113.0 # We can do more complicated calculations as well. Notice # how a long line is split across two lines using the # backslash ( \ ): print "Here is a big negative integer: " ,\ ( 17 * * 21 + 5 ) * ( 36 % 11 + 76 * 43 ) - ( 712 + 5243 * * 32 ) # Try doing different calculations and see what you get! |
ഈ പ്രോഗ്രാം പ്രവര്ത്തിപ്പിക്കേണ്ടതെങ്ങനെ എന്ന് നമുക്കറിയാം: ഒന്നാം പാഠത്തില് ചെയ്തതുപോലെ ഒരു ഫയലില് (ഉദാ: calc.py) പ്രോഗ്രാം എഴുതുക (കോപ്പി-പേസ്റ്റ് ചെയ്താലും മതി), അതുകഴിഞ്ഞ് ടെര്മിനലില് ഫയല് സൂക്ഷിച്ചിരിക്കുന്ന ഡയറക്ടറിയില് ചെന്ന്
python calc.py
എന്ന കമാന്റ് കൊടുക്കുക. ഈ പ്രോഗ്രാമില് പ്രത്യേകം ശ്രദ്ധിക്കേണ്ട കാര്യങ്ങള്:
- ഹരണക്രിയയില് ഉള്പ്പെട്ടിരിക്കുന്ന രണ്ടു സംഖ്യകളൂം ദശാംശ ചിഹ്നം ഇല്ലാത്തവയാണെങ്കില് ഉത്തരവും ദശാംശ ചിഹ്നം ഇല്ലാതെ ശരിക്കുള്ള ഉത്തരത്തിന്റെ പൂര്ണ്ണസംഖ്യാഭാഗം മാത്രമായിരിക്കും. കൂടുതല് കൃത്യമായ ഉത്തരം കിട്ടാന് ഒരു സംഖ്യയിലെങ്കിലും ഒരു ദശാംശ ചിഹ്നം ഇടുക.
-
print
ഉപയോഗിച്ച് ഒന്നിലധികം കാര്യങ്ങള് കാണിക്കാന് കോമ ഉപയോഗിക്കുക. print "5 + 3 = ", 5 + 3
എന്നതിലെ string-നെ അതേപടിയും, string അല്ലാത്ത 5 + 3 എന്നതിന്റെ മൂല്യം കണ്ടുപിടിച്ച് അതും output ആയി കിട്ടുന്നത് ശ്രദ്ധിക്കുക.- വായിക്കാനുള്ള സൗകര്യത്തിനായി ദൈര്ഘ്യമേറിയ ഒരു വരിയെ backslash (\) ഉപയോഗിച്ച് രണ്ടായി മുറിച്ച് എഴുതിയിരിക്കുന്നത് ശ്രദ്ധിക്കുക. ഈ ചിഹ്നമില്ലാതെ ഈ വരിയെ രണ്ടായി മുറിച്ചാല് എന്തു സംഭവിക്കും? പരീക്ഷിച്ചുനോക്കുക!
പ്രോഗ്രാമിംഗ് പഠിക്കാന് വേണ്ട ഒരു ഗുണം പരീക്ഷണങ്ങള് നടത്തിനോക്കാനുള്ള താത്പര്യ്മാണ്: സ്വന്തമായി പലതരം ക്രിയകള് പൈത്തണ് ഉപയോഗിച്ച് ചെയ്തുനോക്കുക. നിങ്ങള് പ്രതീക്ഷിക്കുന്ന ഉത്തരങ്ങള്തന്നെയാണോ കിട്ടുന്നത്? ഉദാഹരണത്തിന്: നിങ്ങള് കൊടുത്ത ക്രിയയില് പൂജ്യം കൊണ്ടുള്ള ഹരണം വേണ്ടിവന്നാല് എന്തു സംഭവിക്കും? ഏതെങ്കിലും ക്രിയയ്ക്ക് മറുപടിയായി പൈത്തണ് പരാതി പറഞ്ഞാല് (error message) അതെന്തുകൊണ്ടാണെന്ന് മനസ്സിലാക്കാന് ശ്രമിക്കുക. മനസ്സിലായില്ലെങ്കില് കൊടുത്ത ക്രിയയും കിട്ടിയ പരാതിയും ഇവിടെ പറയുക: നമുക്കു ചര്ച്ച ചെയ്യാം.
ഗണിതത്തില് താത്പര്യമുള്ളവര്ക്കായി ഒരു പൈത്തണ് പസില് (അല്ലാത്തവര്ക്കും ശ്രമിക്കാം!) : ഈ പാഠത്തില് പരിചയപ്പെട്ട പൈത്തണ് മാത്രമുപയോഗിച്ച് ഒരു സംഖ്യയുടെ വര്ഗമൂലം എങ്ങനെ കാണാം? ഉദാഹരണത്തിന്, നാലിന്റെ വര്ഗമൂലം രണ്ടാണെന്ന് നമുക്കറിയാം. ഇത് പൈത്തണെക്കൊണ്ട് എങ്ങനെ പറയിപ്പിക്കും? രണ്ടിന്റെ (ഏകദേശ) വര്ഗമൂലം കാണാനോ? മൂന്നാം മൂലമാണെങ്കിലോ?
അടുത്ത പാഠത്തില്: പൈത്തണ് പ്രോഗ്രാമുകള് അനായാസം എഴുതി പ്രവര്ത്തിപ്പിച്ചുനോക്കാനുള്ള പുതിയ രണ്ടു വഴികള്.
പൈത്തണ്: പാഠം മൂന്ന്
>> Monday, June 28, 2010
ആമുഖം
കഴിഞ്ഞ രണ്ടു പാഠങ്ങളിലായി കണ്ട ചെറിയ പ്രോഗ്രാമുകള് എഴുതി പ്രവര്ത്തിപ്പിച്ചുനോക്കിക്കാണുമല്ലോ. ഒരു എഡിറ്റര് (ഉദാ: gedit) ഉപയോഗിച്ച് പ്രോഗ്രാം ഒരു ഫയലില് എഴുതി സൂക്ഷിച്ച്, ടെര്മിനലില്
python filename
എന്ന
കമാന്റുപയോഗിച്ച് പ്രോഗ്രാം പ്രവര്ത്തിപ്പിക്കുക എന്നതാണ് ഈ
പ്രോഗ്രാമുകള്ക്ക് നാമവലംബിച്ച രീതി. ഇത് തികച്ചും ശരിയായ
രീതിതന്നെയാണെങ്കിലും ഇതിന് ഒരു പോരായ്മയുണ്ട്. ഗണിതക്രിയകളുടെ പ്രോഗ്രാം
ഉപയോഗിച്ച് പരീക്ഷണങ്ങള് നടത്തുമ്പോഴാണ് ഈ കുറവ് നമുക്ക് ശരിക്കു
ബോധ്യപ്പെടുക. ഇതെന്താണെന്നുവച്ചാല്, പുതിയ ഓരോ കാര്യം
പരീക്ഷിച്ചുനോക്കാനും നാം രണ്ടു കാര്യങ്ങള് ചെയ്യണം. ഉദാഹരണത്തിന്, 2 ** 1/2
എന്നെഴുതിയാല് രണ്ടിന്റെ വര്ഗമൂലം കിട്ടുമോ എന്നറിയാന് താഴെപ്പറയുന്ന കാര്യങ്ങള് ചെയ്യണം:- gedit-ല്
print "The square root of 2 is ", 2 ** 1/2
എന്ന വരി പ്രോഗ്രാമില് ചേര്ത്ത് ഫയല് സേവ് ചെയ്യുക. - ടെര്മിനലിലേക്ക് മാറി
python calc.py
എന്ന കമാന്റ് കൊടുക്കുക.
2 ** (1/2)
എന്നുചെയ്താല് ശരിയുത്തരം കിട്ടണം. ഇതുപരീക്ഷിച്ചുനോക്കാന് നാം
മേല്പ്പറഞ്ഞ രണ്ടു കാര്യങ്ങള് --- ഫയലില് നമുക്കുവേണ്ട മാറ്റങ്ങള്
വരുത്തി സേവ് ചെയ്യുക, ടെര്മിനലില് പൈത്തണ് ദ്വിഭാഷിയെ ഫയല്
ഏല്പ്പിക്കുക --- വീണ്ടും ചെയ്യണം. ഇത്തവണയും ഉത്തരം തെറ്റാണെങ്കില്
ഇനിയൊരു മാറ്റം വരുത്താനും ഇതേപോലെ രണ്ടുകാര്യങ്ങള് ചെയ്യണം. ഇത് വലിയ
ബുദ്ധിമുട്ടുള്ള കാര്യമല്ലെങ്കിലും ചെറിയ ബുദ്ധിമുട്ടുള്ള കാര്യമാണ്. ഒരു
ദിവസം നൂറുകണക്കിനു തവണ ഇതു ചെയ്യേണ്ടി വരുമ്പോള് (പ്രോഗ്രാമിംഗ് ജോലിക്കോ
ഹോബിയായോ ചെയ്യുമ്പോള് ഇത് ഒട്ടും വിരളമല്ല) ഈ ചെറിയ ബുദ്ധിമുട്ടൊരു വലിയ
ബുദ്ധിമുട്ടാകും. ഈ ബുദ്ധിമുട്ട് ഒഴിവാക്കാനുള്ള ഒരു ഉപായമാണ് "പൈത്തണ്
ഷെല്".പൈത്തണ് ദ്വിഭാഷിയുടെ മറ്റൊരു മുഖം
പൈത്തണ് പ്രോഗ്രാമുകള് പ്രവര്ത്തിപ്പിക്കാന് നാം ഇതുവരെ ചെയ്തത് പ്രോഗ്രാം ഒരു ഫയലിലെഴുതി ആ ഫയല് പൈത്തണ് ദ്വിഭാഷിക്ക് കൈമാറുക എന്നതാണല്ലോ. പൈത്തണ് ദ്വിഭാഷിയുമായി സംവദിക്കാന് മറ്റൊരു രീതികൂടി നിലവിലുണ്ട്. ഫയല് ഉപയോഗിച്ചുള്ള രീതിയെക്കാള് ജീവത്തായ, ചുറുചുറുക്കുള്ള രീതിയാണിത്. ഇവിടെ നാം ചോദിക്കുന്ന ചോദ്യത്തിന് പൈത്തണ് ഉടനടി ഉത്തരം തരും; അടുത്ത ചോദ്യം കേള്ക്കാന് തയ്യാറായി നില്ക്കുകയും ചെയ്യും. പൈത്തണുമായി ഒരു സല്ലാപം എന്നുവേണമെങ്കില് ഈ രീതിയെ വിശേഷിപ്പിക്കാം. ചെറിയ ചോദ്യങ്ങള്ക്ക് (ഉദാ:
2 ** (1/2)
എന്നതിന്റെ വിലയെത്ര)
പെട്ടെന്ന് ഉത്തരം കിട്ടും എന്നതാണ് ഈ രീതിയുടെ ഒരു പ്രധാന ഗുണം.
പ്രോഗ്രാം എഴുതുമ്പോള് ഉണ്ടാകുന്ന ചെറിയ സംശയങ്ങള് പെട്ടെന്ന്
തീര്ക്കാനും, താരതമ്യേന വലുതായ ഒരു പ്രോഗ്രാമെഴുതുമ്പോള് ചെറിയ ചെറിയ
പ്രോഗ്രാം "കഷണങ്ങള്" ശരിയാണോ എന്ന് പരീക്ഷിച്ചുനോക്കാനും ഈ രീതി വളരെ
ഫലവത്താണ്. പൈത്തണുമായി സല്ലപിക്കാന് ചെയ്യേണ്ടത് ഇത്രമാത്രം: ടെര്മിനല് തുറന്ന്
python
എന്ന കമാന്റ് കൊടുക്കുക. ഇതിനുമുമ്പ് ചെയ്തതില്നിന്ന് വ്യത്യസ്തമായി ഫയലിന്റെ പേര് കൊടുത്തിട്ടില്ല
എന്നത് ശ്രദ്ധിക്കുക.താഴെക്കാണുന്നതുപോലെ >>> എന്ന ഒരു
പ്രോംപ്റ്റ് (കമാന്റുകള് കൊടുക്കാനുള്ള സൂചകം) തുറന്നുവരുന്നതുകാണാം.
ഇതാണ് പൈത്തണ് ഷെല് (Python shell):$ python Python 2.6.5 (r265:79063, Apr 16 2010, 13:09:56) [GCC 4.4.3] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>>
>>> എന്നു കാണുന്നിടത്ത് പൈത്തണ് ഭാഷയിലുള്ള പ്രോഗ്രാം ശകലങ്ങള് കൊടുക്കാം. Enter അമര്ത്തിയാല് ഉടനടി ഉത്തരവും കിട്ടും. ഉദാഹരണത്തിന്, കഴിഞ്ഞ പാഠത്തില്ക്കണ്ട ചില ക്രിയകള് ഷെല് ഉപയോഗിച്ച് ചെയ്യുമ്പോള്:
$ python Python 2.6.5 (r265:79063, Apr 16 2010, 13:09:56) [GCC 4.4.3] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> 5 + 3 8 >>> 5 - 3 2 >>> 5 * 3 15 >>> 5 / 2 2 >>> 5 ** 3 125 >>> print 5 ** 3 125 >>> print "5 + 3 = ", 5 + 3 5 + 3 = 8 >>> 5 / 2.0 2.5 >>> 355 / 113.0 3.1415929203539825 >>> quit() $
ശ്രദ്ധിക്കേണ്ട കാര്യങ്ങള്:
- ഫയലില് പ്രോഗ്രാമെഴുതിയതില്നിന്ന് വ്യത്യസ്തമായി,
- ഷെല്ലില് ഔട്പുട്ട് കാണാന്
print
എന്ന് പറയേണ്ട കാര്യം മിക്കയിടത്തുമില്ല. ഒരു പൈത്തണ് ശകലം കൊടുത്താല് അതിന്റെ വില (അത് പ്രവര്ത്തിപ്പിച്ചുകിട്ടുന്ന ഫലം) അടുത്ത വരിയില് തനിയെ വരും. - ഷെല്ലിലെഴുതിയ പ്രോഗ്രാം സ്ഥായിയല്ല; ഒരു ഫയലിലും അത് തനിയെ സേവ് ചെയ്യപ്പെടുന്നില്ല.വേണമെങ്കില് നമുക്ക് എഡിറ്ററിലേക്ക് കോപ്പി-പേസ്റ്റ് ചെയ്ത് സൂക്ഷിക്കാം എന്നുമാത്രം.
- ഷെല്ലില് ഔട്പുട്ട് കാണാന്
- ഷെല്ലില്നിന്ന് പുറത്തുകടക്കാന്
quit()
എന്ന് ഒരു പുതിയ വരിയില് എഴുതി Enter അമര്ത്തുക.
സമഗ്ര പൈത്തണ് പ്രോഗ്രാം വികസന പദ്ധതി
പൈത്തണ് പ്രോഗ്രാമുകള് എഴുതി പ്രവര്ത്തിപ്പിച്ചുനോക്കാനുള്ള രണ്ടു വഴികള് നാം കണ്ടു: ഫയല്/ടെര്മിനല് എന്നിവ ഉപയോഗിക്കുന്ന രീതിയും ഷെല് ഉപയോഗിക്കുന്ന രീതിയും. ഇനി ഇതു രണ്ടും ചേര്ന്ന, പ്രോഗ്രാം എഴുതാനും പ്രവര്ത്തിപ്പിച്ചുനോക്കാനും വളരെ എളുപ്പമുള്ള, പ്രോഗ്രാമിന്റെ സമഗ്ര വികസനത്തിന് സഹായകമായ ഒരു സോഫ്ട് വെയറിനെ പരിചയപ്പെടാം. IDLE എന്നുപേരുള്ള ഈ സോഫ്ട് വെയര് തുടക്കക്കാര്ക്ക് പൈത്തണ് പഠിക്കാന് വിശേഷിച്ചും നല്ലതാണെന്ന് പൈത്തണ് ഭാഷയുടെ ഔദ്യോഗിക വെബ്സൈറ്റായ python.org ശുപാര്ശ ചെയ്യുന്നു. IDLE വിന്ഡോസിലും ലിനക്സിലും ലഭ്യമാണ്. ഫയല്/ടെര്മിനല് രീതിയും പൈത്തണ് ഷെല്ലും കണ്ടുകഴിഞ്ഞ ഒരാള്ക്ക് മറ്റൊരാളുടെ സഹായമൊന്നുമില്ലാതെതന്നെ IDLE അനായാസം ഉപയോഗിച്ചുതുടങ്ങാം. എന്നിരുന്നാലും IDLE ഉപയോഗിച്ച് പൈത്തണ് പ്രോഗ്രാമുകള് എഴുതുന്ന രീതി നമുക്ക് വിശദമായിത്തന്നെ പഠിക്കാം. ഏതു പൈത്തണ് പ്രോഗ്രാമും ഫയല്/ടെര്മിനല് രീതിയില് എഴുതി പ്രവര്ത്തിപ്പിക്കാമെങ്കിലും, മുമ്പോട്ടുള്ള പഠനത്തില് പ്രോഗ്രാമുകള് ചെയ്തുനോക്കാന് IDLE ഉപയോഗിക്കുന്നതാവും ഏറ്റവും എളുപ്പം. IDLE ഉപയോഗിക്കാന് പഠിക്കുക എന്നത് വളരെ എളുപ്പമാണുതാനും. പ്രോഗ്രാമുകള് എഴുതാനുള്ള സര്വവിധ സഹായങ്ങളും ഒരുമിച്ച് നല്കുന്ന സോഫ്ട് വെയറുകള് Integrated Development Environment (IDE) എന്ന പേരിലാണ് അറിയപ്പെടുന്നത്. "സമഗ്ര വികസന സാഹചര്യം" എന്നോ മറ്റോ ഇതിനെ പരിഭാഷപ്പെടുത്താം. IDLE (Integrated DeveLopment Environment എന്നതിന്റെ വിചിത്രമായ ചുരുക്കെഴുത്ത്) എന്നത് പൈത്തണ് പ്രോഗ്രാമുകള്ക്കുള്ള ഒരു IDE ആണ്.IDLE ഇന്സ്റ്റാള് ചെയ്യുന്ന വിധം
വിന്ഡോസില്
വിന്ഡോസില് പൈത്തണ് ഇന്സ്റ്റാള് ചെയ്യുമ്പോള് കൂടെ IDLE-ഉം തനിയെ ഇന്സ്റ്റാള് ആവും (വിന്ഡോസ് ഇന്സ്റ്റാളര് ഇവിടെയുണ്ട്. അവിടെ സൂചിപ്പിക്കുന്നതുപോലെ 2.6.5-ആം പതിപ്പ് എടുക്കുന്നതാവും നല്ലത്.).ലിനക്സില്
- സ്കൂള് ലിനക്സില്:
- ഡൗണ്ലോഡ് ചെയ്ത ഫയല് GDebi (3.8-ല് Gdeb) ഉപയോഗിച്ച് തുറക്കുക. ഇതിനായി ഫയലില് റൈറ്റ്-ക്ളിക്ക് ചെയ്ത് "Open with GDebi package installer" (3.8-ല് "Open with GDeb package installer")എന്നത് തെരഞ്ഞെടുക്കുക.
- GDebi തുറന്ന് കുറച്ചുകഴിഞ്ഞ് "Install package" എന്ന ബട്ടണ് തെളിഞ്ഞുവരുമ്പോള് അതമര്ത്തുക, തുടര്ന്നുള്ള നിര്ദ്ദേശങ്ങള് അനുസരിക്കുക. ("Install" എന്നതിനുപകരം "Reinstall" എന്നാണ് കാണുന്നതെങ്കില് അതിനര്ത്ഥം IDLE നേരത്തേതന്നെ ഇന്സ്റ്റാള് ചെയ്തിട്ടുണ്ട് എന്നാണ്; അങ്ങനെയാണെങ്കില് വീണ്ടും ഇന്സ്റ്റാള് ചെയ്യേണ്ട കാര്യമില്ല, GDebi അടയ്കാം.)
- ഉബുണ്ടുവില് (ഇന്റര്നെറ്റ് കണക്ഷന് ഉണ്ടായിരിക്കണം): ടെര്മിനല് തുറന്ന്
sudo apt-get install idle
എന്ന കമാന്റ് കൊടുക്കുക. തുടര്ന്നുള്ള നിര്ദ്ദേശങ്ങള് അനുസരിക്കുക. "[Y/n]?" എന്ന് (Yes/No?) ചോദിക്കുന്നിടത്ത് "Y" എന്ന് ഉത്തരം കൊടുത്ത് Enter അമര്ത്തുക. (ചില സിസ്റ്റങ്ങളില് കമാന്റില് അവസാനം കണ്ടidle
എന്നതിനുപകരംidle-python2.6
എന്ന് കൊടുക്കേണ്ടി വന്നേക്കാം.)
IDLE ഉപയോഗിക്കുന്നതെങ്ങനെ?
ഇന്സ്റ്റാള് ചെയ്തുകഴിഞ്ഞ് IDLE തുറക്കാന് ചെയ്യേണ്ടത്:- വിന്ഡോസില്: All Programs -> Python 2.6 -> Python IDLE
- ലിനക്സില്: Applications -> Programming -> IDLE
calc.py
എന്ന പ്രോഗ്രാം ഈ എഡിറ്ററിലൊന്ന് തുറന്നുനോക്കാം. ഇതിനായി ചെയ്യേണ്ടത്:
- IDLE-ല് File-> Open എന്നത് തെരഞ്ഞെടുക്കുക. (ഇതിനുള്ള എളുപ്പവഴി: Ctrl-O. അതായത് Control, O എന്നീ കീകള് ഒരുമിച്ചമര്ത്തുക)
calc.py
എന്ന ഫയല് സൂക്ഷിച്ചുവെച്ചMyPrograms
എന്ന ഡയറക്ടറിയില്ച്ചെന്ന് ആ ഫയല് തെരഞ്ഞെടുത്ത് Open അമര്ത്തുക . ഈ ഫയല് ഒരു എഡിറ്ററില് തുറന്നുവരുന്നതുകാണാം.
ഒരു ശരാശരി പ്രോഗ്രാം
ഹൈസ്കൂള് കുട്ടികള്ക്കായി ഒരു ക്യാമ്പ് നടത്തുന്നു എന്നു കരുതുക. ജില്ലയിലെ പല സ്കൂളുകളില്നിന്നുള്ള കുട്ടികള് ക്യാമ്പില് പങ്കെടുക്കുന്നു. ക്യാമ്പില് വന്നിട്ടുള്ള കുട്ടികളുടെ ശരാശരി പ്രായം കണ്ടുപിടിക്കാനുള്ള ലളിതമായ ഒരു പ്രോഗ്രാം നമുക്കെഴുതാം. പ്രോഗ്രാമിലേക്ക് ഇന്പുട്ട് കൊടുക്കുന്നവിധം, ചരങ്ങളുടെ (variables) പ്രോഗ്രാമിലെ ഉപയോഗം എന്നിവ ഇതിലൂടെ നമുക്ക് പഠിക്കാം. ഈ പ്രോഗ്രാമിലേക്ക് ഇന്പുട്ട് ആയി കൊടുക്കേണ്ടത് ഓരോ പ്രായത്തിലുമുള്ള എത്ര കുട്ടികള് വീതം ക്യാമ്പില് വന്നിട്ടുണ്ട് എന്നതാണ്. ഹൈസ്കൂള് കുട്ടികളായതിനാല് പ്രായം പന്ത്രണ്ടിനും പതിനാറിനുമിടയ്ക്കായിരിക്കും എന്ന് (മിക്കവാറും എല്ലാവരും എങ്ങനെയെങ്കിലുമൊക്കെ പാസായിപ്പോകുന്ന ഇക്കാലത്തെങ്കിലും) ന്യായമായും കരുതാം. പ്രോഗ്രാം താഴെ കൊടുക്കുന്നു. (കഴിയുമെങ്കില് IDLE ഉപയോഗിച്ച്) പ്രവര്ത്തിപ്പിച്ചുനോക്കുക. സംശയങ്ങളും പ്രശ്നങ്ങളും കമന്റിലൂടെ അറിയിക്കുക. നിങ്ങള് ചോദിക്കുന്ന സംശയങ്ങള്ക്കുള്ള മറുപടികള് കൂടി ഉള്പ്പെടുത്തി പ്രോഗ്രാമിനെപ്പറ്റിയുള്ള വിശദീകരണം അടുത്ത പാഠത്തില്.# This program calculates the average age of a group of students # whose ages range from twelve to sixteen. The program takes as # input the numbers of students of each age and outputs the # average. # # The goal of this program is to show how to read input into the # program, and to introduce the use of variables. num_12 = input("How many 12 year old students in the group? ") num_13 = input("How many 13 year old students in the group? ") num_14 = input("How many 14 year old students in the group? ") num_15 = input("How many 15 year old students in the group? ") num_16 = input("How many 16 year old students in the group? ") total_num = num_12 + num_13 + num_14 + num_15 + num_16 total_age = (12.0 * num_12) + (13 * num_13) + (14 * num_14) + \ (15 * num_15) + (16 * num_16) average = total_age/total_num print "The average age of all the students is ", average
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
| # This program calculates the average age of a group of students # whose ages range from twelve to sixteen. The program takes as # input the numbers of students of each age and outputs the # average. # # The goal of this program is to show how to read input into the # program, and to introduce the use of variables. num_12 = input ( "How many 12 year old students in the group? " ) num_13 = input ( "How many 13 year old students in the group? " ) num_14 = input ( "How many 14 year old students in the group? " ) num_15 = input ( "How many 15 year old students in the group? " ) num_16 = input ( "How many 16 year old students in the group? " ) total_num = num_12 + num_13 + num_14 + num_15 + num_16 total_age = ( 12.0 * num_12) + ( 13 * num_13) + ( 14 * num_14) + \ ( 15 * num_15) + ( 16 * num_16) average = total_age / total_num print "The average age of all the students is " , average |
- IDLE തുറക്കുക (നേരത്തേതന്നെ തുറന്നുവച്ചിട്ടുണ്ടെങ്കില് അത് ഉപയോഗിച്ചാല് മതി; പുതുതായി തുറക്കേണ്ട കാര്യമില്ല.).
- പുതിയ ഒരു (ഒഴിഞ്ഞ) ഫയല് IDLE-ല് തുറക്കുക. ഇതിനായി File -> New Window അല്ലെങ്കില് Ctrl-N എന്ന കുറുക്കുവഴി ഉപയോഗിക്കുക.
- പുതിയ ഫയല് ഒരു എഡിറ്ററിലായാണ് തുറന്നുവരുന്നത്; ഇവിടെ നമുക്ക് ഇഷ്ടമുള്ളതൊക്കെ എഴുതാനുള്ള സൗകര്യമുണ്ട്. ഈ ഫയലിലേക്ക് നമ്മുടെ പ്രോഗ്രാം എഴുതുക അല്ലെങ്കില് പകര്ത്തിവെക്കുക.
- എഴുതിയ പ്രോഗ്രാമിനെ File -> Save അല്ലെങ്കില് Ctrl-S ഉപയോഗിച്ച് (ഒന്നാം പാഠത്തില് gedit ഉപയോഗിച്ച് സേവ് ചെയ്തപ്പോഴുള്ള നിബന്ധനകള് പാലിച്ചുകൊണ്ട് )സേവ് ചെയ്യുക.
- ഇപ്പോള് നമ്മുടെ എഡിറ്ററുടെ തലക്കെട്ട് "Untitled" എന്നതുമാറി സേവ് ചെയ്ത ഡയറക്ടറിയുടെ പേരുള്പ്പടെയുള്ള ഫയലിന്റെ പേരായി മാറിയിരിക്കും. ഇനി ഈ എഡിറ്ററില് നിന്നുകൊണ്ട് (ഇതില് സംശയമുണ്ടെങ്കില് എഡിറ്റര് വിന്ഡോയില് എവിടെയെങ്കിലും മൌസ് ഒന്നു ക്ളിക്ക് ചെയ്താല് മതി) F5 അമര്ത്തുക.
പൈത്തണ്: പാഠം നാല്
>> Monday, July 19, 2010
1
| num_12 = input ( "How many 12 year old students in the group? " ) |
ഈ വരിയില് മൂന്നു കാര്യങ്ങളാണുള്ളത്:
-
num_12
എന്ന വേരിയബിള് (variable) അഥവാ ചരം.
- = എന്ന സംകാരകം (operator).
-
input()
എന്ന, ഡേറ്റ സ്വീകരിക്കാനുള്ള ഉപാധി.
ഇവയോരോന്നും എന്താണെന്നു നോക്കാം.
input()
പ്രോഗ്രാമിലേക്ക് പുറത്തുനിന്ന് ഡേറ്റ എത്തിക്കാനുള്ള ഒരു മാര്ഗമാണ് input()
.
കൃത്യമായി പറഞ്ഞാല്, ടെര്മിനല് ഉപയോഗിച്ച് പ്രോഗ്രാം
പ്രവര്ത്തിപ്പിക്കുന്ന ആളിനോട് ഒരു ചോദ്യം ചോദിച്ച്, ആ
ചോദ്യത്തിനുകിട്ടുന്ന ഉത്തരം പ്രോഗ്രാമിലേക്ക് എത്തിക്കുക എന്നതാണ് input()
ചെയ്യുന്നത്. ഉപയോക്താവിനോട് ചോദിക്കേണ്ട ചോദ്യം input
എന്നതിനു ശേഷം ബ്രായ്ക്കറ്റുകള്ക്കുള്ളിലായി ഒരു string ആയി കൊടുക്കണം — ഉദ്ധരണചിഹ്നങ്ങള്ക്കിടയിലായി (ഉദാ: "How many 12 year old students in the group? "
) കൊടുക്കണമെന്നര്ത്ഥം. input()
പ്രവര്ത്തിക്കുമ്പോള് ഇങ്ങനെ കൊടുത്ത string-നെ അത് ടെര്മിനലില് അഥവാ
ഷെല്ലില് പ്രിന്റ് ചെയ്യുകയും, ഉപയോക്താവ് തരുന്ന ഉത്തരത്തിനായി
കാത്തുനില്ക്കുകയും ചെയ്യും. പ്രോഗ്രാം പ്രവര്ത്തിപ്പിക്കുന്ന ആള്
എന്തെങ്കിലുമൊക്കെ എഴുതി Enter അമര്ത്തുമ്പോള്, Enter-നു മുമ്പുവരെ
എഴുതിയ കാര്യങ്ങള് വായിച്ചെടുത്ത് input()
അത് പ്രോഗ്രാമിലേക്കെത്തിക്കുന്നു. നമ്മുടെ പ്രോഗ്രാമില്
input()
ഉപയോഗിച്ച് വായിച്ചെടുത്തതെല്ലാം സംഖ്യകളാണല്ലോ? സംഖ്യകളല്ലാതെ പേരുകളും മറ്റും പ്രോഗ്രാമിലേക്ക് input()
ഉപയോഗിച്ച് വായിച്ചെടുക്കാന് ശ്രമിച്ചാല് പൈത്തണ് പരാതി
പറയുന്നതുകാണാം. ഈ പരാതിക്കു കാരണമെന്താണെന്ന് നമുക്കു വഴിയേ കാണാം. പരാതി
പരിഹരിക്കാനായി താഴെപ്പറയുന്നതില് ഏതെങ്കിലും ചെയ്യുക:- പേരുകള്, വാചകങ്ങള് മുതലായ string-കള് ഇന്പുട്ട് ആയി കൊടുക്കുമ്പോള് (അതായത്, ടെര്മിനലില്,
input()
-ന്റെ കാത്തുനില്പ്പ് അവസാനിപ്പിക്കാനായി കൊടുക്കുമ്പോള്) അവയെ ഉദ്ധരണചിഹ്നങ്ങള്ക്കുള്ളിലാക്കി, string ആയിത്തന്നെ കൊടുക്കുക. അതായത്, വെറുതെPhilip
എന്ന് കൊടുക്കുന്നതിനുപകരം"Philip"
എന്നു കൊടുക്കുക. അല്ലെങ്കില്
- പ്രോഗ്രാമില്
input()
എന്നതിനുപകരംraw_input()
ഉപയോഗിക്കുക. ഇങ്ങനെയാണെങ്കില് പ്രോഗ്രാം പ്രവര്ത്തിക്കുന്ന സമയത്ത് string-കള് ഇന്പുട്ടായി കൊടുക്കുമ്പോള് " " എന്നതിനുള്ളിലായി കൊടുക്കണമെന്നില്ല.
നമ്മുടെ ആദ്യത്തെ പ്രോഗ്രാം ഓര്മ്മയില്ലേ? "Hello, World!" എന്ന് എഴുതുന്ന പ്രോഗ്രാമായിരുന്നു അത്.
input()
എന്ന ഇന്പുട്ട് എടുക്കുന്ന ഉപാധിയെപ്പറ്റി മനസ്സിലാക്കിയ സ്ഥിതിക്ക് നമുക്ക് ഈ പ്രോഗ്രാമിനെ ഒന്ന് മെച്ചപ്പെടുത്താം:ഒരു പ്രവര്ത്തനം
- പ്രവ. 1.
- ഉപയോക്താവിനോട് പേരു ചോദിക്കുകയും, പേരു കിട്ടിക്കഴിഞ്ഞാല് ആ പേരുവച്ച് ഹലോ പറയുകയും ചെയ്യുന്ന ഒരു പ്രോഗ്രാം എഴുതുക.
num_12
num_12
എന്നത് ഒരു ചരം (variable - വേരിയബിള്) ആണ്. ലളിതമായിപ്പറഞ്ഞാല് മൂല്യങ്ങളെ (values) സൂക്ഷിച്ചുവെക്കാനുള്ള പേരെഴുതിയ പെട്ടികളാണ്
ചരങ്ങള്. ഒരു പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനത്തിന്റെ ഭാഗമായി സാധാരണഗതിയില്
കുറെയേറെ വിലകള് അഥവാ മൂല്യങ്ങള് ഉപയോഗിക്കേണ്ടതായിവരും.
പ്രോഗ്രാമിനുപുറത്തുനിന്ന് (ഉദാ: input()
വഴിയായി) കിട്ടുന്ന
ഡേറ്റയും, പ്രോഗ്രാം പ്രവര്ത്തിപ്പിക്കുമ്പോളുണ്ടാകുന്ന മറ്റു മൂല്യങ്ങളും
ഇതില് ഉള്പ്പെടും. ഇവയില് ചിലതിനെയൊക്കെ നമുക്ക് പേരിട്ടു വിളിക്കേണ്ട
ആവശ്യവുമുണ്ടാകും. ഇങ്ങനെ വിലകളെ പേരിട്ടു വിളിക്കാനുള്ള ഉപാധിയാണ്
ചരങ്ങള്. പ്രോഗ്രാമിംഗില് ചരങ്ങള്ക്ക് വളരെയേറെ പ്രാധാന്യമുണ്ട്. പ്രോഗ്രാമുകള് ശരിയായി എഴുതാന് ചരങ്ങള് എന്താണെന്ന് കൃത്യമായി മനസ്സിലാക്കുകയും അവയെ ശരിയായി ഉപയോഗിക്കുവാന് അറിയുകയും വേണം. ചരങ്ങളുടെ പിന്നിലുള്ള ആശയം ലളിതമായതുകൊണ്ട് ഇതത്ര പ്രയാസമുള്ള കാര്യമൊന്നുമല്ല. ചരങ്ങളുടെ ഉപയോഗത്തില് വളരെ പ്രാധാന്യമുള്ള = എന്ന സംകാരകത്തിനെ പരിചയപ്പെട്ടതിനുശേഷം ചരങ്ങളെപ്പറ്റി നമുക്ക് വിശദമായി ഈ പാഠത്തില്ത്തന്നെ പഠിക്കാം.
=
എന്ന സംകാരകം (operator)
നമ്മുടെ ശരാശരി പ്രോഗ്രാമിന്റെ ആദ്യത്തെ വരി ഒരിക്കല്ക്കൂടി എടുത്തെഴുതുന്നു:
1
| num_12 = input ( "How many 12 year old students in the group? " ) |
ഇതില്
num_12
, input()
എന്നിവയെ ബന്ധിപ്പിക്കുന്ന =
എന്ന ചിഹ്നം ചെയ്യുന്നത് വലതുവശത്തുള്ള input()
എന്നതിന്റെ വില (മൂല്യം) എടുത്ത് ഇടതുവശത്തുള്ള num_12
എന്ന ചരത്തിന് കൊടുക്കുക എന്നതാണ്. അതായത്, =
എന്നത് ഒരു "വിലകൊടുക്കല് സംകാരകം" (assignment operator എന്ന് ഇംഗ്ളീഷില്) യാണ്. ഗണിത സമവാക്യങ്ങളില് ഉപയോഗിക്കുന്നതുപോലെ തുല്യത കാണിക്കുന്നതിനുവേണ്ടി അല്ല =
എന്നത് പൈത്തണില് ഉപയോഗിക്കുന്നത് എന്നത് പ്രത്യേകം ശ്രദ്ധിക്കേണ്ട കാര്യമാണ് . ഉദാഹരണത്തിന്, ഗണിതത്തില് വെറും പൊട്ടത്തെറ്റായ x = x + 1
എന്നത് പൈത്തണില് സാധുതയുള്ള പ്രസ്താവമാണ്! ഇതെങ്ങനെയാണ് ശരിയാകുന്നത് എന്നുകാണാന്
=
എന്ന് പ്രോഗ്രാമില് കാണുന്നിടത്ത് അതിനുപകരം ←
ആണ് എന്ന് സങ്കല്പ്പിക്കുക. അപ്പോള് x = x + 1
എന്നത് x ← x + 1
എന്നാകും (സങ്കല്പ്പത്തില്). ഇതിനെ വായിക്കേണ്ടത് ഇങ്ങനെയാണ്: " ←
-ന്റെ വലതുവശത്തുകാണുന്ന വ്യഞ്ജകത്തിന്റെ (expression) വില കണ്ടുപിടിച്ച് അത് ←
-ന്റെ ഇടതുവശത്തുകാണുന്ന ചരത്തിന് കൊടുക്കുക." ഇങ്ങനെയാകുമ്പോള് x ← x + 1
എന്നതിന്റെ അര്ത്ഥം ഇനിപ്പറയുന്നതാണ്: "x
എന്ന ചരത്തിന്റെ ഇനിയുള്ള വില എന്നത് x
-ന് മുമ്പുണ്ടായിരുന്ന വിലയുടെ കൂടെ 1
കൂട്ടിയാല് കിട്ടുന്ന മൂല്യമാണ്". ഇതുതന്നെയാണ് x = x + 1
എന്നു പറയുമ്പോള് സംഭവിക്കുന്നതും. ഇതു നമുക്കൊന്ന് പരീക്ഷിച്ചുനോക്കാം.
ഇതിനായി IDLE-ലെ പൈത്തണ് ഷെല്ലില് പോകുക (ടെര്മിനലില് പൈത്തണ് ഷെല്
തുറന്നാലും മതി). താഴെക്കാണുന്നവ പരീക്ഷിക്കുക:Python 2.6.5 (r265:79063, Apr 16 2010, 13:57:41) [GCC 4.4.3] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> x = 5 >>> x 5 >>> x = x + 1 >>> x 6 >>>
-
x
എന്ന ചരത്തിന്5
എന്ന വില കൊടുക്കാന്x = 5
എന്ന് കൊടുത്ത് Enter അമര്ത്തുന്നു.
-
x
-ന്റെ വില കാണാന് വെറുതെx
എന്ന് കൊടുത്ത് Enter അമര്ത്തുന്നു. ഷെല്ലിലായതുകൊണ്ടാണ് ഇത് മതിയാകുന്നത്. ഫയലിലെഴുതിയ പ്രോഗ്രാമിലാണെങ്കില്print x
എന്ന് എഴുതണം.
-
x
-ന്റെ വില ഒന്നു കൂട്ടാന്x = x + 1
എന്ന് കൊടുക്കുന്നു.
-
x
-ന്റെ വില മാറിയോ എന്നു കാണാന് വീണ്ടുംx
എന്ന് കൊടുക്കുന്നു.
ഇതുതന്നെ ഒരു ചെറിയ പ്രോഗ്രാമാക്കി എഴുതിയാല് ഇതുപോലെയിരിക്കും:
1
2
3
4
5
6
7
8
9
| # A short program to show the assignment operator in action. x = 5 print x x = x + 1 print x |
ഇത്തരം ചെറിയ കാര്യങ്ങള് ചെയ്തുനോക്കാന് ഷെല് തന്നെയാണ് സൗകര്യം.
പ്രോഗ്രാമില് കാണുന്ന=
എന്ന ചിഹ്നത്തിന് ഗണിതത്തില് കാണുന്ന = എന്ന ചിഹ്നത്തിന്റെ അതേ അര്ത്ഥം അല്ല എന്ന ബോധം ഉറയ്ക്കാന്വേണ്ടി കുറേക്കാലത്തേക്കെങ്കിലും പ്രോഗ്രാമില്=
എന്ന് കാണുന്നിടത്തെല്ലാം←
എന്ന ചിഹ്നം മനസ്സില്ക്കാണുക .
പ്രവര്ത്തനങ്ങള്
(എല്ലാം ഷെല്ലില് (IDLE-ലോ ടെര്മിനലിലോ) ചെയ്യേണ്ടവ.)- പ്രവ. 2.
-
മുകളില്പ്പറഞ്ഞ കാര്യങ്ങള് ഷെല്ലില് ചെയ്യുക. അതിനു തുടര്ച്ചയായി
x
-ന്റെ വില ഇരട്ടിപ്പിക്കുക:x
-ന്റെ വിലയെ രണ്ടുകൊണ്ട് ഗുണിച്ച്x
-ലേക്കുതന്നെ കൊടുക്കുക. ഇതുകഴിഞ്ഞുള്ളx
-ന്റെ വില കാണുക, ഇരട്ടിച്ചു എന്ന് ഉറപ്പുവരുത്തുക. - പ്രവ. 3.
-
y
എന്ന ചരത്തിന്10
എന്ന വില കൊടുക്കുക.z
എന്ന ചരത്തിന്x
,y
എന്നിവയുടെ തുക വിലയായി കൊടുക്കുക.z
-ന്റെ വില കാണുക. - പ്രവ. 4.
-
a
എന്ന ചരത്തിന്"silsila "
എന്ന വില കൊടുക്കുക.b
എന്ന ചരത്തിന്"hai "
എന്ന വില കൊടുക്കുക (ഉദ്ധരണചിഹ്നങ്ങളും സ്പേസും ശ്രദ്ധിക്കുക).c
എന്ന ചരത്തിന്a + b + a
എന്ന വില കൊടുക്കുക. ഇപ്പോള്c
-യുടെ വില എന്താണ്? - പ്രവ. 5.
-
c
-യുടെ വില ഇരട്ടിപ്പിക്കുക:c
-യുടെ വിലയെ രണ്ടുകൊണ്ട് ഗുണിച്ച് (അതെ!)c
-ലേക്കുതന്നെ കൊടുക്കുക. ഇതുകഴിഞ്ഞുള്ളc
-യുടെ വില കാണുക.
ശരാശരി പ്രോഗ്രാമിന്റെ വിവരണം
കഴിഞ്ഞ പാഠത്തിലെ ശരാശരി കണ്ടുപിടിക്കുന്ന പ്രോഗ്രാം മനസ്സിലാക്കാനുള്ളതെല്ലാം നാം പഠിച്ചുകഴിഞ്ഞു. പ്രോഗ്രാം എടുത്തെഴുതുന്നു.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
| # This program calculates the average age of a group of # students whose ages range from twelve to sixteen. The # program takes as input the numbers of students of each age # and outputs the average. # # The goal of this program is to show how to read input into # the program, and to introduce the use of variables. num_12 = input ( "How many 12 year old students in the group? " ) num_13 = input ( "How many 13 year old students in the group? " ) num_14 = input ( "How many 14 year old students in the group? " ) num_15 = input ( "How many 15 year old students in the group? " ) num_16 = input ( "How many 16 year old students in the group? " ) total_num = num_12 + num_13 + num_14 + num_15 + num_16 total_age = ( 12.0 * num_12) + ( 13 * num_13) + ( 14 * num_14) + \ ( 15 * num_15) + ( 16 * num_16) average = total_age / total_num print "The average age of all the students is " , average |
പ്രോഗ്രാമിന്റെ ആദ്യത്തെ ഏഴു വരികള് കമന്റുകളും പിന്നെയുള്ള രണ്ടു വരികള് ശൂന്യവുമാണല്ലോ. പത്തു മുതല് പതിനെട്ടു വരെ വരികളില് ചെയ്യുന്നത് ഉപയോക്താവിന്റെ പക്കല്നിന്ന് അഞ്ച് വിലകള് (ഇവ പൂര്ണ്ണ സംഖ്യകളാണെന്നാണ് സങ്കല്പം) വാങ്ങി അഞ്ച് ചരങ്ങളിലേക്ക് (
num_12, num_13, num_14, num_15, num_16
) സൂക്ഷിച്ചു വെക്കുക (store) എന്നതാണ്. ഇതിനായി നാം മുകളില് വിവരിച്ച രീതിയില് input(), =
എന്നിവ ഉപയോഗിച്ചിരിക്കുന്നു. ഇരുപതാം വരിയില് ചെയ്യുന്നത്
total_num
എന്ന ചരത്തിലേക്ക്
മറ്റ് അഞ്ച് ചരങ്ങളുടേയും തുക (ഇത് കുട്ടികളുടെ എണ്ണമാണ്)
സൂക്ഷിച്ചുവെക്കുക എന്നതാണ്. ഇരുപത്തിരണ്ടാം വരിയിലാകട്ടെ കുട്ടികളുടെ
വയസുകളുടെയെല്ലാം തുക total_age
എന്ന ചരത്തിലേക്ക് സൂക്ഷിച്ചുവെക്കുന്നു. ഇതിയായി =
ചിഹ്നത്തിന്റെ വലതുഭാഗത്ത് ഈ തുക തരുന്ന ഒരു വ്യഞ്ജകം (expression)
എഴുതിയിരിക്കുന്നു. ഇവിടെ വലത്തേക്ക് നീണ്ടുപോകുമായിരുന്ന വ്യഞ്ജകത്തെ \
എന്ന ചിഹ്നത്തിന്റെ സഹായത്തോടെ രണ്ടു വരികളിലാക്കിയിരിക്കുന്നത്
ശ്രദ്ധിക്കുക: പ്രോഗ്രാം കാണുമ്പോഴുള്ള ഭംഗിക്കുവേണ്ടിയും വായിക്കാനുള്ള
സൗകര്യത്തിനുവേണ്ടിയും മാത്രമാണ് ഇങ്ങനെ ചെയ്യുന്നത്. \
ഒഴിവാക്കി ഒരേ വരിയില് വ്യഞ്ജകം മുഴുവന് എഴുതിയാലും പ്രോഗ്രാം ഒരു
വ്യത്യാസവുമില്ലാതെ പ്രവര്ത്തിച്ചുകൊള്ളും (ഇങ്ങനെയാക്കി നോക്കൂ). ഇരുപത്തിയഞ്ചാം വരിയില്
total_age
എന്ന ചരത്തിന്റെ വിലയെ total_num
എന്ന ചരത്തിന്റെ വിലകൊണ്ട് ഹരിച്ചുകിട്ടുന്ന ഫലത്തെ average
എന്ന ചരത്തിലേക്ക് സൂക്ഷിച്ചു വെക്കുന്നു. പ്രോഗ്രാമിലെ അവസാനത്തെ
വരിയില് ഇങ്ങനെ കിട്ടിയ ശരാശരി ഒരു വാചകത്തിന്റെ ഒടുവിലായി
പുറത്തേക്കെഴുതുമ്പോള് പ്രോഗ്രാം വിജയകരമായി പൂര്ത്തിയാകുന്നു.ചരങ്ങള്
മൂല്യങ്ങളെ (values) പേരിട്ടു വിളിക്കാനായി പ്രോഗ്രാമില് ചരങ്ങള് (variables) ഉപയോഗിക്കുന്നത് നാം കണ്ടു. ഇനി നമുക്ക് ചരങ്ങളെപ്പറ്റി കുറച്ചുകൂടി വിശദമായി പഠിക്കാം. ചരങ്ങളുടെ പിന്നിലെ ആശയം മനസ്സിലാക്കാന് എളുപ്പമുള്ളതാണ്. ഇതു ശരിയായി മനസ്സിലാക്കാതിരുന്നാലോ, പ്രോഗ്രാമെഴുത്ത് ദുഷ്കരമാകുകയും ചെയ്യും.ഒരു ചരത്തിന് രണ്ട് ഭാഗങ്ങളുണ്ട് — പേരും, മൂല്യവും:
ചരത്തിന്റെ പേര് (name അല്ലെങ്കില് label)
- ശരാശരി കാണാനുള്ള പ്രോഗ്രാമില് നാമുപയോഗിച്ച് ചരങ്ങളുടെ പേരുകള്
num_12, num_13, num_14, num_15, num_16, total_num, total_age, average
എന്നിവയാണ്. ചരങ്ങള്ക്ക് പേരുകൊടുക്കുമ്പോള് പാലിക്കേണ്ട ചില നിയമങ്ങളുണ്ട്. അവ ഇവിടെ ചുരുക്കി പറയുന്നു:- പേരുകള്ക്ക് എത്രവേണമെങ്കിലും നീളം ആകാം.
- പേരിന്റെ ആദ്യത്തെ അക്ഷരം ഇംഗ്ളീഷ് അക്ഷരമാലയിലെ ഏതെങ്കിലും അക്ഷരം (ചെറിയതോ വലിയതോ) അല്ലെങ്കില് "_"-ഓ (underscore) ആയിരിക്കണം.
- പേരിന്റെ രണ്ടാമത്തേതും തുടര്ന്നുമുള്ള സ്ഥാനങ്ങളില് മേല്പ്പറഞ്ഞ അക്ഷരങ്ങളും "_"-ഉം കൂടാതെ അക്കങ്ങളും ആകാം.
- പേരുകളില് വലിയക്ഷരവും ചെറിയക്ഷരവും (capital and small letters) തമ്മില് വ്യത്യാസമുണ്ട്. ഉദാ:
average, Average
എന്നിവ രണ്ടു വ്യത്യസ്ത ചരങ്ങളാണ്; ഒന്നിനു പകരം മറ്റേത് ഉപയോഗിച്ചാല് പ്രോഗ്രാം തെറ്റിപ്പോകും.
- താഴെക്കാണുന്ന പേരുകള് വിലക്കപ്പെട്ടവയാണ്. ഇവ ചരങ്ങളുടെ പേരുകളായി ഉപയോഗിച്ചുകൂടാ .
ഇതിനുകാരണം ഇവയ്ക്ക് പൈത്തണ് ഭാഷയില് പ്രത്യേക അര്ത്ഥങ്ങള് ഉണ്ട്
എന്നതാണ്. ഇവയെ കീവേഡുകള് (keywords) –
പ്രത്യേകവാക്കുകള്/പ്രധാനവാക്കുകള് – എന്നു വിളിക്കുന്നു.
and del from not while as elif global or with assert else if pass yield break except import print class exec in raise continue finally is return def for lambda try
- "_" പേരിന്റെ തുടക്കത്തില് അനുവദനീയമാണെങ്കിലും തുടക്കക്കാരായ
നമ്മള് ഈ സൗകര്യം ഉപയോഗിക്കാതെയിരിക്കുന്നതാണ് നല്ലത്. പേരിന്റെ
തുടക്കത്തിലെ "_" വിട്ടുപോകാനും കാണാതെയിരിക്കാനും നല്ല
സാധ്യതയുള്ളതുകൊണ്ടാണ് ഇങ്ങനെ പറഞ്ഞത്.
- മേല്ക്കൊടുത്ത നിയമങ്ങളനുസരിക്കുന്ന ഏതു പേരും
ചരങ്ങള്ക്കിടാമെങ്കിലും ചരത്തിനെ എന്ത് സൂചിപ്പിക്കാനാണോ പ്രോഗ്രാമില്
ഉപയോഗിക്കുന്നത്, ആ അര്ത്ഥം വരുന്ന പേരുകള് ഇടുന്നതാണ് നല്ലത്. ഇത്
പ്രോഗ്രാം വായന സുകരമാക്കും. ശരാശരി കാണാനുള്ള നമ്മുടെ പ്രോഗ്രാമില്
ഉപയോഗിച്ചിരിക്കുന്ന ചരങ്ങളുടെ പേരുകള് ശ്രദ്ധിക്കുക.
- ഒറ്റനോട്ടത്തില് ഒന്നാണെന്ന് തോന്നിക്കുന്ന പേരുകള് കൊടുക്കാതെയിരിക്കുക.
average, Average
എന്നീ രണ്ടു പേരുകളും ഒരേ പ്രോഗ്രാമില് ഉപയോഗിച്ചാല് ചിന്താക്കുഴപ്പവും അതുമൂലമുള്ള തെറ്റുകളും വരാന് കാരണം വേറെയൊന്നും വേണ്ട.
- പേരുകള്ക്ക് എത്രവേണമെങ്കിലും നീളം ആകാം.
ചരത്തിന്റെ മൂല്യം (value)
-
ഒരു ചരത്തിന് പ്രോഗ്രാമിലെ ആവശ്യമനുസരിച്ച് പല തരത്തിലുള്ള — സംഖ്യ,
string, മുതലായ — വിലകള് ആകാം. ചരങ്ങളെപ്പറ്റി ചിന്തിക്കാനുള്ള എളുപ്പവഴി
അവയെ വിലകള് സൂക്ഷിക്കാനുള്ള കള്ളികളായി (cells) സങ്കല്പ്പിക്കുക
എന്നതാണ്. ഇതനുസരിച്ച് നമ്മുടെ പ്രോഗ്രാമിലെ പത്താമത്തെ വരി
പ്രവര്ത്തിക്കുന്നതിനുമുമ്പ്
num_12
എന്ന ചരം ഇങ്ങനെയിരിക്കും: ചരത്തിന്റെ വില (value) സൂക്ഷിക്കുന്ന ഭാഗത്ത് ഒന്നുമില്ല എന്നത് ശ്രദ്ധിക്കുക. പ്രോഗ്രാമിലെ പത്താമത്തെ വരി പ്രവര്ത്തിക്കുമ്പോഴുണ്ടാകുന്ന ചോദ്യത്തിന് ഉത്തരമായി നിങ്ങള് 10 എന്ന സംഖ്യ കൊടുത്ത് Enter അമര്ത്തി എന്ന് കരുതുക. അപ്പോള് ഇതേ ചരത്തിന്റെ അവസ്ഥ ഇങ്ങനെയായി മാറും: പ്രോഗ്രാം പതിനെട്ടാമത്തെ വരി വരെ പ്രവര്ത്തിച്ചുകഴിയുമ്പോള് ചരങ്ങളുടെ അവസ്ഥ (ഈ സംഖ്യകളൊക്കെ ഇന്പുട്ട് ആയി കിട്ടിയാല്): ഇരുപതാമത്തെ വരി കഴിയുമ്പോള്: ഇങ്ങനെ തുടര്ന്ന്, പ്രോഗ്രാമിന്റെ അവസാനമാകുമ്പോഴേക്കും:
ചരങ്ങളും
=
-ഉം ഉള്പ്പെടുന്ന ഒരു പൈത്തണ് വരി വായിക്കേണ്ട രീതി:-
=
-ന് വലതുവശത്ത് (ഒറ്റയ്കോ ഒരു വ്യഞ്ജകത്തിന്റെ ഭാഗമായോ) കാണുന്ന ചരങ്ങള് താന്താങ്ങളുടെ വിലകളെ ആണ് സൂചിപ്പിക്കുന്നത്. അതുകൊണ്ട് ഇങ്ങനെയുള്ള ഓരോ ചരത്തിനും പകരമായി അതിന്റെ ഇപ്പോഴത്തെ വില അതേ സ്ഥാനത്ത് സങ്കല്പ്പിക്കുക.
-
=
-ന്റെ ഇടതുവശത്ത് ഒരേ ഒരു ചരമേ ആകാവൂ. ഒന്നിലധികം ചരങ്ങളുള്ള വ്യഞ്ജകങ്ങള് പാടില്ല (ഇതിന് അപവാദങ്ങളുണ്ട്, വഴിയേ കാണാം).=
-ന്റെ ഇടതുവശത്ത് കാണുന്ന ചരം അതിന്റെ വിലയെ അല്ല സൂചിപ്പിക്കുന്നത്, മറിച്ച് അതിന്റെ കള്ളിയെ (cell, location) ആണ്. ഈ കള്ളിയിലേക്ക്=
-ന്റെ വലതുവശത്തുള്ള വ്യഞ്ജകത്തിന്റെ വില എഴുതുന്നതായി സങ്കല്പ്പിക്കുക.
x
എന്ന ഒരു ചരത്തിന്റെ വില പല തരത്തില് മാറ്റുന്ന ഒരു കൂട്ടം പൈത്തണ് ശകലങ്ങള് ഇതാ. ഓരോ പ്രാവശ്യവും x
-ന്റെ വില മാറുമ്പോള് x
-ന്റെ
വില സൂക്ഷിച്ചിരിക്കുന്ന പേരിട്ട പെട്ടിക്ക് എന്ത് സംഭവിക്കുന്നു എന്ന്
കാണിക്കുന്ന ചിത്രങ്ങള് താഴെ. ഈ പെട്ടി കംപ്യൂട്ടറിന്റെ മെമ്മറിയില്
(RAM) ആണ് നിലകൊള്ളുന്നത്. ഒരു പ്രോഗ്രാം പ്രവര്ത്തിക്കുന്നിടത്തോളം സമയം ആ
പ്രോഗ്രാമില് ഉപയോഗിക്കുന്ന ചരങ്ങളുടെ പെട്ടികള് മെമ്മറിയില് കാണും.
പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനം നിലയ്ക്കുമ്പോള് ഈ പെട്ടികളും
അപ്രത്യക്ഷമാവും; അവ ഉപയോഗിച്ച മെമ്മറി മറ്റു പ്രോഗ്രാമുകള്ക്ക്
ഉപയോഗിക്കാന് വിട്ടുകിട്ടുകയും ചെയ്യും. Python 2.6.5 (r265:79063, Apr 16 2010, 13:57:41) [GCC 4.4.3] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> x = 5 >>> x 5 >>> x = "Maths" >>> x 'Maths' >>> x = 2 * x >>> x 'MathsMaths' >>> x = x + x >>> x 'MathsMathsMathsMaths' >>> x = 10 >>> x 10 >>>
(കൂടുതല് വ്യക്തമായ ചിത്രം കാണാന് ചിത്രത്തില് ക്ളിക്ക് ചെയ്യുക.)
ഒരു പ്രവര്ത്തനം
- പ്രവ. 6.
- പ്രോഗ്രാമില് വിട്ടുപോയ വരികള് പൂരിപ്പിക്കുക
# ..........
എന്നു കാണുന്ന ഭാഗത്ത് ) പൂരിപ്പിച്ച് a, b
എന്നീ ചരങ്ങളുടെ മൂല്യം പരസ്പരം മാറുന്ന രീതിയില് ആക്കുക. പ്രോഗ്രാമിന്റെ മറ്റുഭാഗങ്ങളില് മാറ്റം വരുത്താതെ വേണം ഇത് ചെയ്യേണ്ടത്.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
| # A progam that exchanges the values of two variables. a = raw_input ( "Please enter a value for the first variable: " ) b = raw_input ( "Please enter a value for the second variable: " ) print "The value of the first variable is: " , a print "The value of the second variable is: " , b print "Going to exchange the values of the two variables..." print "............................." print "............................." # Write code below that will exchange the values of the two # variables a and b. # .......... # .......... # .......... # .......... print "Successfully exchanged the values of the two variables." print "The value of the first variable is: " , a print "The value of the second variable is: " , b |
ഇങ്ങനെ ചെയ്തുകഴിയുമ്പോള് പ്രോഗ്രാം പ്രവര്ത്തിക്കുന്നത് ഇതുപോലെയായിരിക്കണം (വ്യക്തമായ ചിത്രത്തിന് ക്ളിക്ക് ചെയ്യുക):
ഉത്തരങ്ങളും സംശയങ്ങളും നിര്ദ്ദേശങ്ങളും കമന്റായിടുക.
പൈത്തണ്: പാഠം അഞ്ച്
>> Tuesday, August 3, 2010
ജനിച്ച വര്ഷം കണ്ടുപിടിക്കുന്നതെങ്ങനെ?
കഴിഞ്ഞ പാഠത്തിന്റെ കമന്റുകളില് "Free" എന്ന വായനക്കാരി (രന്?) അവതരിപ്പിച്ച പ്രവര്ത്തനം ഒന്നു നോക്കാം. ചോദ്യം ഇതാണ്: " ഒരാളുടെ പേരും വയസും ഇന്പുട്ട് ആയി എടുത്ത് അയാള് ജനിച്ച വര്ഷം ഔട്പുട്ട് തരുന്ന പ്രോഗ്രാം എഴുതുക." ഈ പ്രവര്ത്തനത്തിന് "digitaleye" എന്ന വായനക്കാരന് (രി?) തന്ന ഉത്തരം കുറച്ചുകൂടി വിശദമാക്കി എഴുതിയ ഒരു പ്രോഗ്രാം ഇതാ. പ്രോഗ്രാം ഒരു ഫയലിലേക്ക് സേവ് ചെയ്ത് പല പ്രാവശ്യം പ്രവര്ത്തിപ്പിച്ചു നോക്കൂ. ഇതിനുള്ള എളുപ്പവഴി IDLE ഉപയോഗിക്കുക എന്നതാണ്, ഇവിടെ പറഞ്ഞിരിക്കുന്നതുപോലെ.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
| # This program asks for the name and age (in number of # years) of the user, and outputs the year when the user was # born. name = raw_input ( "Hello, what is your name? " ) question = name + ", please tell me your age in years: " age = input (question) current_year = 2010 year_of_birth = current_year - age print name, ", you were born in " , year_of_birth print "Goodbye!" |
പ്രോഗ്രാമിന്റെ അഞ്ചാമത്തെ വരിയില് ഉപയോക്താവിന്റെ പേര്
raw_input()
ഉപയോഗിച്ച് പ്രോഗ്രാമിലെ name
എന്ന ചരത്തിലേക്ക് എത്തിക്കുന്നു. ഇവിടെ ഉപയോക്താവിനോട് ചോദിക്കേണ്ട
ചോദ്യം ഒരു string ആയി തയ്യാറാക്കിയിരിക്കുന്ന രീതി പ്രത്യേകം
ശ്രദ്ധിക്കുക. +
എന്ന സംകാരകം (operator) സംഖ്യകളുടെ തുക
കാണാന് മാത്രമല്ല, string-കളെ കൂട്ടിച്ചേര്ത്ത് ഒറ്റ string ആക്കാനും
പൈത്തണില് ഉപയോഗിക്കാം. ഉദാഹരണം:Python 2.6.5 (r265:79063, Apr 16 2010, 13:09:56) [GCC 4.4.3] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> 1+1 2 >>> "1" + "1" '11' >>>
മുകളിലെ പ്രോഗ്രാമില് ഉപയോക്താവിനെ പേരുള്പ്പടെ സംബോധന ചെയ്യാനായി ഈ വിദ്യ പ്രയോഗിച്ചിരിക്കുന്നു. ഏഴാമത്തെ വരിയില് ഇന്പുട്ട് ആയി കിട്ടിയ പേരും ചോദിക്കേണ്ട ചോദ്യവും
+
എന്ന സംകാരകം ഉപയോഗിച്ച് ഒറ്റ string ആക്കി question
എന്ന ചരത്തില് സൂക്ഷിക്കുന്നു. ഒന്പതാമത്തെ വരിയില് ഉപയോക്താവിനോട് വയസ് ചോദിച്ച് age
എന്ന ചരത്തില് സൂക്ഷിക്കുന്നു. ഇതിനു വേണ്ടി മുമ്പത്തെ പാഠത്തില് കണ്ടതുപോലെ input()
ഉപയോഗിക്കുന്നു. input()
-ന്റെ ബ്രായ്ക്കറ്റിനുള്ളില് ഉപയോക്താവിനോട് ചോദിക്കേണ്ട ചോദ്യം കൊടുക്കേണ്ടിടത്ത് question
എന്ന ചരം കൊടുത്തിരിക്കുന്നത് ശ്രദ്ധിക്കുക. ഈ ചരത്തിന്റെ വില (മൂല്യം, value) നാം ഏഴാമത്തെ വരിയില് +
ഉപയോഗിച്ച് തയ്യാറാക്കിയ string ആണ്. പ്രോഗ്രാമില് ഏതെങ്കിലും വില വേണ്ടതായ സ്ഥലങ്ങളിലൊക്കെ അതിനു പകരം അതേ വിലയുള്ള ചരം ഉപയോഗിക്കാം. ഇവിടെ നാം ചെയ്തിരിക്കുന്നതും ഇതുതന്നെ.പ്രോഗ്രാമിന്റെ പതിനൊന്നാമത്തെ വരിയില് നടപ്പുവര്ഷം ഏതെന്ന്
current_year
എന്ന ചരത്തില് സൂക്ഷിച്ചുവെയ്ക്കുന്നു. അര്ത്ഥവത്തായ പേരുകളുള്ള ചരങ്ങളുടെ ഉപയോഗം പ്രോഗ്രാം വായന സുകരമാക്കാന് സഹായിക്കുന്നു. നമ്മുടെ പ്രോഗ്രാം വളരെ ചെറിയ ഒന്നായതുകൊണ്ട് ഇങ്ങനെ ചെയ്യുന്നതുകൊണ്ട് — 2010
എന്ന് നേരിട്ട് പറയുന്നതിനു പകരം current_year
എന്ന ചരത്തില് ഈ വില സൂക്ഷിച്ചുവെച്ച് നടപ്പുവര്ഷം വേണ്ടിടത്തെല്ലാം ഈ
ചരം ഉപയോഗിക്കുന്നതുകൊണ്ട് — ഉള്ള പ്രയോജനം എന്താണെന്നത് അത്രകണ്ട്
വ്യക്തമല്ല. എന്നാല് കുറച്ചു വലിയ ഒരു പ്രോഗ്രാമിലോ? പേരില്ലാത്ത കുറെയേറെ
സംഖ്യകള് പ്രോഗ്രാമില് ഉണ്ടെങ്കില് അത് പ്രോഗ്രാം വായിക്കുന്ന ആളെ
കുഴക്കാനേ ഉപകരിക്കൂ. ഓരോ സംഖ്യയും എന്തര്ത്ഥത്തിലാണ്
ഉപയോഗിച്ചിരിക്കുന്നത് എന്നറിയാന് ആ സംഖ്യ എവിടെയൊക്കെയാണ്
ഉപയോഗിച്ചിരിക്കുന്നതെന്ന് കണ്ടുപിടിച്ച് തല പുകയ്ക്കേണ്ടിവരും.
അതുകൊണ്ടുതന്നെ ഇങ്ങനെയുള്ള സംഖ്യക്ളെ അര്ത്ഥം വ്യക്തമാകുന്ന രീതിയിലുള്ള
പേരുകള് കൊടുത്ത് പ്രോഗ്രാമില് ഉപയോഗിക്കുന്നതാണ് മെച്ചം, ഇവിടെ
ചെയ്തതുപോലെ. പ്രോഗ്രാമിന്റെ പതിമൂന്നാമത്തെ വരിയില് ഉപയോക്താവ് ജനിച്ച വര്ഷം കണ്ടുപിടിക്കാനായി നടപ്പുവര്ഷത്തില്നിന്ന് വയസ് കുറയ്ക്കുന്നു. അവസാനത്തെ രണ്ടു വരികളില് ഇങ്ങനെ കിട്ടിയ ഉത്തരം ഔട്പുട്ട് ചെയ്യുകയും ചെയ്യുന്നു.
ബഗ്!
ഇത് താരതമ്യേന വളരെ ചെറിയതായ, ലളിതമായ ഒരു പ്രോഗ്രാം ആണ്. "Free" അവതരിപ്പിച്ച പ്രവര്ത്തനത്തിന് ഈ പ്രോഗ്രാം മതിയായ ഉത്തരവും ആണ്. എന്നാല് ഈ പ്രോഗ്രാമിന് അത്ര ചെറുതല്ലാത്ത ഒരു പ്രശ്നം ഉണ്ട്. ഈ പ്രശ്നം കാരണം ഒട്ടേറെപ്പേരുടെ കാര്യത്തില് ഈ പ്രോഗ്രാം തെറ്റായ ഉത്തരം തരും! ഒന്നാന്തരം ഒരു ബഗ് (കീടം?) നമ്മുടെ പ്രോഗ്രാമില് ഉണ്ട് എന്നര്ത്ഥം. ഇതുപോലെയുള്ള പ്രശ്നങ്ങള് പ്രോഗ്രാമിന്റെ ലോജിക്കില് നുഴഞ്ഞുകയറാതെ ശ്രദ്ധിക്കാന് പഠിക്കുക എന്നത് നല്ല രീതിയില് പ്രോഗ്രാം എഴുതാന് പഠിക്കുന്നതിന്റെ അതിപ്രധാനമായ ഭാഗമാണ്. ഒരാള് ജനിച്ച വര്ഷം കണ്ടുപിടിക്കാനുള്ള മുകളില്ക്കൊടുത്ത പ്രോഗ്രാം എപ്പോഴൊക്കെയാണ് തെറ്റായ ഉത്തരം തരുന്നത് എന്ന് ആലോചിച്ചു നോക്കൂ. ഒരു പത്തുമിനിട്ട് മനസ്സിരുത്തി ആലോചിച്ച്, പ്രോഗ്രാമിന് കിട്ടാവുന്ന പല തരത്തിലുള്ള (ശരിയായ) ഇന്പുട്ടുകള് ഏതൊക്കെയാണ്, അവയ്ക്കെല്ലാം പ്രോഗ്രാം ശരിയായ മറുപടി തരുമോ എന്നൊക്കെ തിരിച്ചും മറിച്ചും ചിന്തിച്ചുനോക്കി പ്രശ്നം പിടികിട്ടുന്നില്ലെങ്കില് മാത്രം അടുത്ത ഖണ്ഡിക നോക്കുക.
...
...
...
...
...
...
നാം പ്രോഗ്രാം പ്രവര്ത്തിപ്പിക്കുന്നത് 2010 ഓഗസ്റ്റ് തുടക്കത്തില് ആണെന്ന് കരുതുക. പ്രോഗ്രാമിലെ പ്രശ്നം എന്താണെന്ന് മനസ്സിലാക്കാന് ഹരി, ജോണ് എന്ന രണ്ടു സുഹൃത്തുക്കളുടെ കാര്യമെടുക്കാം. ഹരിക്ക് പ്രായം 15 വയസും 10 മാസവും. ജോണിന് 15 വയസും 2 മാസവും (അതുകൊണ്ടു തന്നെ മാത്സ് ബ്ളോഗിനു പിന്നിലെ ഹരി, ജോണ് സാറന്മാരല്ല ഇവരെന്ന് മനസ്സിലായല്ലോ.). നമ്മുടെ പ്രോഗ്രാമിന്റെ ചോദ്യത്തിന് രണ്ടുപേരും 15 എന്ന് ഉത്തരം കൊടുക്കും. രണ്ടുപേരും ജനിച്ചത് 1995-ല് ആണെന്ന് പ്രോഗ്രാം പറയുകയും ചെയ്യും. ജോണിന്റെ കാര്യത്തില് ഇത് ശരിയാണ്. ഹരിയുടെ കാര്യത്തില് ശരിയല്ലതാനും! ഹരി ജനിച്ചത് 1994 സെപ്റ്റംബര് അവസാനം ആണ്.
ഈ കീടത്തെ എങ്ങനെ ശരിപ്പെടുത്താം?
ബഗ് ഉണ്ടെന്ന് മനസ്സിലായ സ്ഥിതിക്ക് അത് ഒഴിവാക്കുന്ന തരത്തില് പ്രോഗ്രാം തിരുത്തി എഴുതേണ്ടത് നമ്മുടെ കടമയാണ് (ഈ പ്രക്രിയയെ "കീടോച്ഛാടനം" എന്നു വിളിക്കാമോ?). ഹരിയുടെ കാര്യത്തില് പ്രോഗ്രാമില്നിന്ന് തെറ്റായ ഉത്തരം കിട്ടാന് എന്താണ് കാരണം? പ്രോഗ്രാമിന് ശരിയായ ഉത്തരം കണ്ടുപിടിക്കാന് ആവശ്യമായ വിവരങ്ങള് എല്ലാം ഇന്പുട്ട് ആയി നാം കൊടുക്കാത്തതുതന്നെ. വയസിന്റെ കുറച്ചുകൂടി കൃത്യമായ വിവരം — എത്ര വര്ഷം എന്നതിന് പുറമേ എത്ര മാസം എന്നതുകൂടി — ഇന്പുട്ട് ആയി പ്രോഗ്രാമിന് കിട്ടിയാല് മേല്പ്പറഞ്ഞ തെറ്റ് ഒഴിവാക്കുന്ന പ്രോഗ്രാം നമുക്കെഴുതാം. ഇങ്ങനെയുള്ള ഒരു പ്രോഗ്രാമിന്റെ ലോജിക് ഏകദേശം ഇതുപോലെയിരിക്കും:
- ഉപയോക്താവിന്റെ പ്രായം എത്ര വര്ഷം, എത്ര മാസം എന്നത് ചോദിച്ച് മനസ്സിലാക്കുക.
- വര്ഷത്തിനെ
years
എന്ന ചരത്തില് സൂക്ഷിച്ചു വെയ്ക്കുക. - മാസത്തിനെ
months
എന്ന ചരത്തില് സൂക്ഷിച്ചു വെയ്ക്കുക. - നടപ്പുവര്ഷവും മാസവും
current_year
,current_month
എന്ന ചരങ്ങളില് സൂക്ഷിച്ചു വെയ്ക്കുക. -
months
എന്നതിന്റെ വിലcurrent_month
എന്നതിന്റെ വിലയേക്കാള് കുറവാണെങ്കില് -
current_year - years
എന്നതാണ് ഉപയോക്താവ് ജനിച്ച വര്ഷം; ഈ വിലയെyear_of_birth
എന്ന ചരത്തില് സൂക്ഷിച്ചു വെയ്ക്കുക. - മറിച്ച്,
months
എന്നതിന്റെ വിലcurrent_month
എന്നതിന്റെ വിലയ്ക്ക് തുല്യമോ അതില് കൂടുതലോ ആണെങ്കില് -
current_year - years - 1
എന്നതാണ് ഉപയോക്താവ് ജനിച്ച വര്ഷം; ഈ വിലയെyear_of_birth
എന്ന ചരത്തില് സൂക്ഷിച്ചു വെയ്ക്കുക. year_of_birth
എന്ന ചരത്തിന്റെ വിലയാണ് ഉപയോക്താവ് ജനിച്ച വര്ഷം എന്ന് ഉത്തരം പറയുക.
പ്രവര്ത്തനങ്ങള്
- പ്രവ. 1.
- ഈ ലോജിക് ശ്രദ്ധിച്ച് വായിക്കുക. ഇത് ഹരി ജനിച്ച വര്ഷം ശരിയായി കണ്ടുപിടിക്കുമോ എന്ന് ചിന്തിക്കുക.
- പ്രവ. 2.
- ഇപ്പറഞ്ഞ ലോജിക് എങ്ങനെ ഒരു പ്രോഗ്രാം ആയി എഴുതാം എന്ന് ആലോചിക്കുക.
if ... else
മുകളിലുള്ള ലോജിക്കിന് ആകെ അഞ്ചു ഭാഗങ്ങള് ഉള്ളതില് ആദ്യത്തെ രണ്ടു ഭാഗങ്ങള് പ്രോഗ്രാമില് എഴുതേണ്ടതെങ്ങനെ എന്ന് നമുക്കറിയാം – മുമ്പു കണ്ട പ്രോഗ്രാമുകളില് നാം ഇതേപോലെയുള്ള കാര്യങ്ങള് ചെയ്തിട്ടുണ്ട്. ലോജിക്കിന്റെ അഞ്ചാമത്തെ ഭാഗവും — കണ്ടുപിടിച്ച ഉത്തരം ഉപയോക്താവിന് പറഞ്ഞുകൊടുക്കുക എന്നുള്ളത് — ഇപ്പോള് നമുക്ക് നിഷ്പ്രയാസം ചെയ്യാന് അറിയാം.
പ്രശ്നക്കാരായിട്ട് ഉള്ളത് മൂന്നും നാലും ഭാഗങ്ങളാണ്: ഒരു പ്രത്യേക കാര്യം —
months
എന്നതിന്റെ വില current_month
എന്നതിന്റെ വിലയേക്കാള് കുറവാണോ എന്നത് — ശരിയാണോ എന്ന് പരിശോധിച്ച്, ഇത്
ശരിയാണെങ്കില് ഒരു കാര്യവും, തെറ്റാണെങ്കില് വേറൊരു കാര്യവും ചെയ്യുക
എന്നതാണ് ഈ രണ്ട് ഭാഗങ്ങളില് സംഭവിക്കുന്നത്. ഇത് എങ്ങനെയാണ്
പ്രോഗ്രാമില് എഴുതുക എന്ന് നാം ഇതുവരെയുള്ള പാഠങ്ങളില് പഠിച്ചിട്ടില്ല.
ഇക്കാര്യം ഈ പാഠത്തില് പഠിക്കാം.നാം ഇതുവരെ കണ്ട പൈത്തണ് പ്രോഗ്രാമുകളെല്ലാം ഒരു നേര്രേഖാ സ്വഭാവം ഉള്ളവയാണ്: പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനം തുടങ്ങിയാല്പ്പിന്നെ പ്രോഗ്രാമിലെ ഓരോ വരിയും പ്രോഗ്രാമില് എഴുതിയിരിക്കുന്ന ക്രമത്തില് പ്രവര്ത്തിച്ചുപോകുക എന്ന രീതിയാണ് അവയ്ക്കൊക്കെ ഉള്ളത്. ഇങ്ങനെ "നേര്ബുദ്ധി" മാത്രമുള്ള പ്രോഗ്രാമുകളെക്കൊണ്ട് വളരെ പരിമിതങ്ങളായ കാര്യങ്ങളേ ചെയ്യാന് കഴിയൂ. ഇങ്ങനെയല്ലാത്ത — രേഖീയമല്ലാത്ത — രീതിയില് പ്രോഗ്രാം പ്രവര്ത്തിപ്പിക്കാനുള്ള പൈത്തണ് ഭാഷാരൂപങ്ങളില് ഏറ്റവും ലളിതമായതാണ്
if ... else
എന്ന പ്രയോഗം.ഒരു വ്യവസ്ഥ (condition) ശരിയാണോ എന്ന് പരിശോധിച്ച്, ശരിയാണെങ്കില് ഒരു കൂട്ടം കാര്യങ്ങളും, തെറ്റാണെങ്കില് മറ്റൊരുകൂട്ടം കാര്യങ്ങളും ചെയ്യാന് പൈത്തണില് (മറ്റു പ്രോഗ്രാമിംഗ് ഭാഷകളിലും) ഉള്ള ഉപാധിയാണ്
if ... else
എന്ന പ്രയോഗം. ഉദാഹരണമായി, if ... else
ഉപയോഗിച്ച് ഒരു സംഖ്യ ഒറ്റസംഖ്യയോ ഇരട്ടസംഖ്യയോ എന്ന് കണ്ടുപിടിക്കുന്ന ഒരു പ്രോഗ്രാം ഇതാ. രണ്ടാം പാഠത്തില് നാം പരിചയപ്പെട്ട ശിഷ്ടം കാണാനുള്ള %
എന്ന സംകാരകവും (operator) ഇവിടെ ഉപയോഗിച്ചിരിക്കുന്നു:
1
2
3
4
5
6
7
8
9
10
11
| # This program finds if a given number is odd or even. The # program demonstrates the use of the "if ... else" program # construct. It is assumed that the input number is an # integer! number = input ( "Please input an integer: " ) if (number % 2 ) = = 0 : print number, " is an even number" else : print number, " is an odd number" |
ഈ പ്രോഗ്രാമില് എട്ടു മുതല് പതിനൊന്നു വരെയുള്ള വരികളിലാണ്
if ... else
ഉള്ളത്. ഈ വരികളില് എന്താണ് ചെയ്യുന്നതെന്ന് നമുക്ക് വിശദമായി നോക്കാം:- എട്ടും ഒന്പതും വരികളില് ചെയ്യുന്നത് ഇതാണ്:
number
എന്ന ചരത്തില് സൂക്ഷിച്ചിരിക്കുന്ന സംഖ്യയെ രണ്ടു കൊണ്ടു ഹരിച്ചാല് ശിഷ്ടം പൂജ്യമാണെങ്കില്number
ഇരട്ടസംഖ്യയാണെന്ന് പറയുക. - എട്ടാമത്തെ വരിയില് ശരിയാണോ എന്ന് പരിശോധിക്കേണ്ട വ്യവസ്ഥ
if
എന്നതിനു ശേഷവും:
എന്നതിനു മുമ്പായും കൊടുത്തിരിക്കുന്നു. -
%
എന്ന ചിഹ്നം പൈത്തണില് ശിഷ്ടം കാണാനുള്ള സംകാരകത്തെ സൂചിപ്പിക്കുന്നു.(number % 2)
എന്ന വ്യഞ്ജകത്തിന്റെ വിലnumber
-നെ രണ്ടുകൊണ്ടു ഹരിച്ചാല് ശിഷ്ടം കിട്ടുന്ന സംഖ്യയാണ്. ഇത് പൂജ്യമോ ഒന്നോ ആയിരിക്കും (എന്തുകൊണ്ട്?). -
==
എന്ന ചിഹ്നം (രണ്ടു സമചിഹ്നങ്ങള് അടുപ്പിച്ച് എഴുതിയത്) പൈത്തണില് തുല്യത പരിശോധിക്കുന്ന സംകാരകത്തെ സൂചിപ്പിക്കുന്നു. - എട്ടാമത്തെ വരി വായിക്കേണ്ടത് " number-നെ രണ്ടുകൊണ്ട് ഹരിച്ചാല് ശിഷ്ടം പൂജ്യമാണെങ്കില് " എന്നാണ്.
- വ്യവസ്ഥ ശരിയാണെങ്കില് ചെയ്യേണ്ട കാര്യങ്ങള് —
number
ഇരട്ടസംഖ്യയാണെന്ന് പറയുക എന്നുള്ളത് —if ... :
കഴിഞ്ഞുള്ള വരിയില് വലതുവശത്തേക്ക് കുറച്ച് മാറ്റി കൊടുത്തിരിക്കുന്നു. - പത്തും പതിനൊന്നും വരികളില് ചെയ്യുന്നത് ഇതാണ്: എട്ടാമത്തെ വരിയില് പരിശോധിച്ച വ്യവസ്ഥ —
number
എന്ന ചരത്തില് സൂക്ഷിച്ചിരിക്കുന്ന സംഖ്യയെ രണ്ടു കൊണ്ടു ഹരിച്ചാല് ശിഷ്ടം പൂജ്യമാണോ എന്നത് — തെറ്റാണെങ്കില്number
ഒറ്റസംഖ്യയാണെന്ന് പറയുക. - "എട്ടാമത്തെ വരിയിലെ
if
-ല് പരിശോധിച്ച വ്യവസ്ഥ തെറ്റാണെങ്കില്" എന്ന് പ്രോഗ്രാമില് ചുരുക്കിപ്പറയാനായിelse :
എന്ന് പ്രയോഗിക്കുന്നു. - ഈ വ്യവസ്ഥ തെറ്റുമ്പോള് ചെയ്യേണ്ട കാര്യങ്ങള് —
number
ഒറ്റസംഖ്യയാണെന്ന് പറയുക എന്നുള്ളത് —else :
കഴിഞ്ഞുള്ള വരിയില് വലതുവശത്തേക്ക് കുറച്ച് മാറ്റി കൊടുത്തിരിക്കുന്നു.
if ... else
: വിശദമായി
if ... else
പ്രോഗ്രാമില് ഉപയോഗിക്കുന്ന വിധം നമുക്ക് കുറച്ചുകൂടി വിശദമായി പരിശോധിക്കാം:-
if
വരിയുടെ വ്യാകരണം ഇതാണ്:if condition :
. ഇവിടെcondition
എന്നത് നമുക്ക് ശരിയോ തെറ്റോ എന്ന് അറിയേണ്ടതായ വ്യവസ്ഥ ആണ്. മുകളിലെ ഉദാഹരണത്തില് ഈ വ്യവസ്ഥ(number % 2) == 0
എന്നതാണ്.condition
കഴിഞ്ഞുള്ള:
പ്രത്യേകം ശ്രദ്ധിക്കുക . -
if
വരി കഴിഞ്ഞുള്ള വരികളില്condition
എന്ന വ്യവസ്ഥ ശരിയാണെങ്കില് ചെയ്യേണ്ടതായ കാര്യങ്ങള് എഴുതണം. ഇത് ഒന്നിലധികം വരികളും ആവാം. ഇങ്ങനെയുള്ള വരികള് എല്ലാം തന്നെ ഈif
വരിയെ അപേക്ഷിച്ച് ഒരു നിശ്ചിത അകലം വലതുവശത്തേക്ക് മാറി ആയിരിക്കണം തുടങ്ങേണ്ടത്. - മുകളിലെ ഉദാഹരണത്തില് നാലു സ്പേസ് വലത്തേക്ക് മാറിയാണ് എഴുതിയിട്ടുള്ളത് (ഒന്പതാമത്തെ വരി). ഇങ്ങനെ നാലു സ്പേസ് വിട്ടെഴുതുന്നതാണ് പൈത്തണ് മാനകം (standard).
- IDLE ഉപയോഗിച്ച് പ്രോഗ്രാം എഴുതുകയാണെങ്കില്
if condition :
എന്നെഴുതി Enter അമര്ത്തുമ്പോള് IDLE തനിയെ തന്നെ എഴുതിത്തുടങ്ങാനുള്ള സൂചകം (cursor) പുതിയ വരിയില് നാലു സ്പേസ് വലത്തേക്ക് മാറ്റിത്തരുന്നത് കാണാം. ഇതൊന്ന് പരീക്ഷിച്ചു നോക്കൂ! ഇങ്ങനെ മാറുന്നില്ലെങ്കില് തൊട്ടുമുമ്പത്തെ വരിയുടെ വ്യാകരണം തെറ്റിയതാവും കാരണം. മിക്കവാറും ഇത് അവസാനം കൊടുക്കേണ്ടതായ:
വിട്ടുപോയതുകൊണ്ടാവും. -
if
-ല് പരിശോധിച്ച വ്യവസ്ഥ ശരി ആണെങ്കില് ചെയ്യേണ്ടതായ കാര്യങ്ങള് എഴുതിക്കഴിഞ്ഞാല് പിന്നീടുള്ള വരിif
വരി തുടങ്ങുന്ന അതേ അകലം ഇടതുവശത്തുനിന്ന് വിട്ട് വേണം തുടങ്ങാന്. അതായത്, നാലു സ്പേസ് വലത്തേക്ക് മാറി എഴുതുന്നത് നിര്ത്തണം എന്നര്ത്ഥം.if
വ്യവസ്ഥ ശരി ആണെങ്കില് ചെയ്യേണ്ടതായ കാര്യങ്ങള് ഏതൊക്കെയാണെന്ന് പൈത്തണ് മനസ്സിലാക്കുന്നത്if
-നു ശേഷംif
-ന്റെ അതേ നിരപ്പിലുള്ള ആദ്യത്തെ വരി കാണുന്നതിന് മുന്പായി നാലു സ്പേസ് വലത്തേക്ക് മാറി വരുന്ന വരികള് ഏതൊക്കെയാണ് എന്ന് നോക്കിയിട്ടാണ്. - മുകളിലെ ഉദാഹരണത്തില്
if
വ്യവസ്ഥ ശരി ആണെങ്കില് ചെയ്യേണ്ടതായ ഒരേ ഒരു കാര്യമേ ഉള്ളൂ —number
ഇരട്ടസംഖ്യയാണെന്ന് പറയുക എന്നത്. ഈ ഒരു വരി മാത്രം (ഒന്പതാമത്തെ വരി) അതുകൊണ്ട് നാലു സ്പേസ് വലത്തേക്ക് തള്ളി എഴുതിയിരിക്കുന്നു. -
else
വരിയുടെ വ്യാകരണം ഇതാണ്:else :
.else
കഴിഞ്ഞുള്ള:
പ്രത്യേകം ശ്രദ്ധിക്കുക . -
else
-ന്റെ അതേ നിരപ്പില് എഴുതിയിട്ടുള്ള, തൊട്ടു മുന്പുള്ളif
വരിയുടെ വ്യവസ്ഥ തെറ്റാണെങ്കില് ചെയ്യേണ്ടതായ കാര്യങ്ങളാണ്else
വരി കഴിഞ്ഞ് എഴുതേണ്ടത്. ഇത് ഒന്നിലധികം വരികളും ആവാം. ഇങ്ങനെയുള്ള വരികള് എല്ലാം തന്നെ ഈelse
വരിയെ അപേക്ഷിച്ച് ഒരു നിശ്ചിത അകലം വലതുവശത്തേക്ക് മാറി ആയിരിക്കണം തുടങ്ങേണ്ടത്. - മുകളിലെ ഉദാഹരണത്തില് പൈത്തണ് മാനകത്തിനനുസരിച്ച് നാലു സ്പേസ് വലത്തേക്ക് മാറിയാണ് എഴുതിയിട്ടുള്ളത് (പതിനൊന്നാമത്തെ വരി).
- IDLE ഉപയോഗിച്ച് പ്രോഗ്രാം എഴുതുകയാണെങ്കില്
else :
എന്നെഴുതി Enter അമര്ത്തുമ്പോള് IDLE തനിയെ തന്നെ എഴുതിത്തുടങ്ങാനുള്ള സൂചകം (cursor) പുതിയ വരിയില് നാലു സ്പേസ് വലത്തേക്ക് മാറ്റിത്തരുന്നത് കാണാം. പരീക്ഷിച്ചു നോക്കുക. ഇങ്ങനെ മാറുന്നില്ലെങ്കില് തൊട്ടുമുമ്പത്തെ വരിയുടെ വ്യാകരണം തെറ്റിയതാവും കാരണം. മിക്കപ്പോഴും ഇത് അവസാനം കൊടുക്കേണ്ടതായ:
വിട്ടുപോയതുകൊണ്ടാവും. -
if
-ല് പരിശോധിച്ച വ്യവസ്ഥ തെറ്റാണെങ്കില് ചെയ്യേണ്ടതായ കാര്യങ്ങള് എഴുതിക്കഴിഞ്ഞാല് പിന്നീടുള്ള വരിif
വരി തുടങ്ങുന്ന അതേ അകലം ഇടതുവശത്തുനിന്ന് വിട്ട് വേണം തുടങ്ങാന്. അതായത്, നാലു സ്പേസ് വലതേക്ക് മാറി എഴുതുന്നത് നിര്ത്തണം എന്നര്ത്ഥം.if
വ്യവസ്ഥ തെറ്റാണെങ്കില് ചെയ്യേണ്ടതായ കാര്യങ്ങള് ഏതൊക്കെയാണെന്ന് പൈത്തണ് മനസ്സിലാക്കുന്നത്else
-നു ശേഷവുംelse
-ന്റെ അതേ നിരപ്പിലുള്ള ആദ്യത്തെ വരി കാണുന്നതിന് മുന്പും നാലു സ്പേസ് വലത്തേക്ക് മാറി വരുന്ന വരികള് ഏതൊക്കെയാണ് എന്ന് നോക്കിയിട്ടാണ്. - മുകളിലെ ഉദാഹരണത്തില്
if
വ്യവസ്ഥ തെറ്റാണെങ്കില് ചെയ്യേണ്ടതായ ഒരേ ഒരു കാര്യമേ ഉള്ളൂ —number
ഒറ്റസംഖ്യയാണെന്ന് പറയുക എന്നത്. ഈ ഒരു വരി മാത്രം (പതിനൊന്നാമത്തെ വരി) അതുകൊണ്ട് നാലു സ്പേസ് വലത്തേക്ക് തള്ളി എഴുതിയിരിക്കുന്നു. - ഇവിടെ നാലു സ്പേസ് എന്ന് പറഞ്ഞയിടത്തൊക്കെ അതിനു പകരം വേറെ ഏതെങ്കിലും ഒരു നിശ്ചിത അകലം ഇതേ ആവശ്യത്തിന് ഉപയോഗിക്കാം. ഉദാഹരണത്തിന്, ഒരു ടാബ് (കംപ്യൂട്ടറിന്റെ Tab കീ അമര്ത്തിയാല് കിട്ടുന്നത്) ഇതിനായി ഉപയോഗിക്കാം. ഒരേ പ്രോഗ്രാമില് ടാബുകളും സ്പേസുകളും രണ്ടുംകൂടി ഈ ആവശ്യത്തിന് ഉപയോഗിക്കരുത്. ഈ ആവശ്യത്തിന് നാലു സ്പേസ് ഉപയോഗിക്കുന്നതാണ് നല്ല പൈത്തണ് ശൈലിയായി കണക്കാക്കുന്നത്.
-
if ... else
-ലെelse
ആവശ്യമില്ലെങ്കില് വിട്ടുകളയാവുന്നതാണ് (optional). (തികച്ചും കൃത്രിമമായ ഒരു) ഉദാഹരണമായി, തന്നിരിക്കുന്ന സംഖ്യ ഇരട്ടസംഖ്യയാണെങ്കില് അത് വിളിച്ചുപറയുകയും ഒറ്റസംഖ്യയാണെങ്കില് ഒന്നും പറയാതിരിക്കുകയും ചെയ്യുന്ന ഒരു പ്രോഗ്രാം ഇതാ:
123456789# When the given number is even, this program reports that
# fact. Otherwise it does not report anything. Used to
# demonstrate an "if" without a corresponding "else" part.
# It is assumed that the input number is an integer!
number
=
input
(
"Please input an integer: "
)
if
(number
%
2
)
=
=
0
:
print
number,
" is an even number"
ഒറ്റയും ഇരട്ടയും സംഖ്യകള് ഈ പ്രോഗ്രാമിന് ഇന്പുട്ട് ആയി കൊടുക്കുമ്പോള് എന്താണ് സംഭവിക്കുന്നത് എന്ന് പ്രവര്ത്തിപ്പിച്ചു കണ്ടുപിടിക്കൂ.
തുലന സംകാരകങ്ങള്
ഒരു സംഖ്യ ഒറ്റയോ ഇരട്ടയോ എന്ന് കണ്ടുപിടിക്കാനുള്ള പ്രോഗ്രാമില് നാം
==
എന്ന തുല്യത പരിശോധിക്കാനുള്ള സംകാരകം (operator) ഉപയോഗിച്ചല്ലോ. ==
-നു പുറമേ മറ്റ് തുലനസംകാരകങ്ങളും (comparison operators) പൈത്തണില് ലഭ്യമാണ്. ഈ സംകാരകങ്ങള് എല്ലാംതന്നെ True, False
എന്നീ രണ്ടു പ്രത്യേക മൂല്യങ്ങള് ഉത്തരമായി തരുന്നവയാണ്. പേര്
സൂചിപ്പിക്കുന്നതുപോലെ തന്നെ ശരി, തെറ്റ് എന്നീ അര്ത്ഥങ്ങളാണ് യഥാക്രമം True, False
എന്ന മൂല്യങ്ങള്ക്ക് പൈത്തണില് ഉള്ളത്. ==
എന്ന സംകാരകം നമുക്ക് ഒറ്റനോട്ടത്തില് തോന്നുന്നതുപോലെ തന്നെയാണ് പെരുമാറുന്നതും: a, b
എന്നിവ സ്ഥിരാങ്കങ്ങളോ (constants) ചരങ്ങളോ ആയിക്കൊള്ളട്ടെ. a == b
എന്നതിന്റെ വില -
a, b
എന്നിവയുടെ വിലകള് രണ്ടും തുല്യമാണെങ്കില്True
ആയിരിക്കും. -
a, b
എന്നിവയുടെ വിലകള് രണ്ടും തുല്യമല്ലെങ്കില്False
ആയിരിക്കും.
പൈത്തണ് പ്രോഗ്രാമുകളില് ധാരാളമായി ഉപയോഗിക്കുന്ന ചില തുലനസംകാരകങ്ങളുടെ പ്രയോഗം വ്യക്തമാക്കുന്ന പട്ടിക. ഇവിടെ
a, b
എന്നിവ സ്ഥിരാങ്കങ്ങളോ (constants) ചരങ്ങളോ (variables) ആകാം: തുലന സംകാരകം | പ്രയോഗം | രണ്ടാം കോളത്തിലെ വ്യഞ്ജകത്തിന്റെ വില | |
---|---|---|---|
True ആകുന്നത് | False ആകുന്നത് | ||
== | a == b | a, b എന്നിവയുടെ വിലകള് തുല്യമാണെങ്കില് | a, b എന്നിവയുടെ വിലകള് തുല്യമല്ലെങ്കില് |
!= | a != b | a, b എന്നിവയുടെ വിലകള് തുല്യമല്ലെങ്കില് | a, b എന്നിവയുടെ വിലകള് തുല്യമാണെങ്കില് |
< | a < b | a -യുടെ വില b -യുടെ വിലയെക്കാള് കുറവാണെങ്കില് | a -യുടെ വില b -യുടെ വിലയെക്കാള് കുറവല്ലെങ്കില് |
> | a > b | a -യുടെ വില b -യുടെ വിലയെക്കാള് കൂടുതലാണെങ്കില് | a -യുടെ വില b -യുടെ വിലയെക്കാള് കൂടുതലല്ലെങ്കില് |
<= | a <= b | a -യുടെ വില b -യുടെ വിലയ്ക്ക് തുല്യമോ അതില് കുറവോ ആണെങ്കില് | a -യുടെ വില b -യുടെ വിലയെക്കാള് കൂടുതലാണെങ്കില് |
>= | a >= b | a -യുടെ വില b -യുടെ വിലയ്ക്ക് തുല്യമോ അതില് കൂടുതലോ ആണെങ്കില് | a -യുടെ വില b -യുടെ വിലയെക്കാള് കുറവാണെങ്കില് |
==
എന്ന സംകാരകത്തെ പ്രോഗ്രാമില് കാണുമ്പോള് ഇംഗ്ളീഷില് വായിക്കുന്നത് "equals" അല്ലെങ്കില് "equal to" എന്നാണ്. !=
-നെ
വായിക്കുന്നത് "not equal to" എന്നും. ഇങ്ങനെയോ തത്തുല്യങ്ങളായ മലയാള
വാക്കുകളായോ (ഏതാണ് നമുക്ക് കൂടുതല് സ്വാഭാവികമായി തോന്നുന്നത്
എന്നതനുസരിച്ച്) ഈ ചിഹ്നങ്ങളെ വായിക്കാം. മുമ്പു പറഞ്ഞതുപോലെ, "നേര്രേഖാ" പ്രോഗ്രാമുകളെക്കൊണ്ട് കുറച്ചു കാര്യങ്ങളേ ചെയ്യാന് കഴിയൂ. മറ്റു പ്രോഗ്രാമുകളിലൊക്കെ ഒന്നല്ലെങ്കില് മറ്റൊരു രീതിയില് തുലനം (comparison) കടന്നു വരുമെന്ന് ഉറപ്പിക്കാം. അതുകൊണ്ടു തന്നെ ഇനി നാം എഴുതുന്ന പ്രോഗ്രാമുകളിലെല്ലാം ഒരു തുലനസംകാരകമെങ്കിലും ഉപയോഗിക്കേണ്ടി വരും എന്ന് നിസ്സംശയം പറയാം. തുലനസംകാരകങ്ങള് ശരിയായി പ്രയോഗിക്കേണ്ടതെങ്ങനെ എന്ന് അനവധി ഉദാഹരണങ്ങളിലൂടെ നമുക്ക് പഠിച്ചെടുക്കാം.
ഒരു സംഖ്യ ന്യൂനസംഖ്യയാണോ, അധിസംഖ്യയാണോ, ഇനി ഇതു രണ്ടുമല്ല പൂജ്യമാണോ എന്ന് കണ്ടുപിടിക്കുന്ന ഒരു പ്രോഗ്രാം നമുക്കൊന്ന് എഴുതി നോക്കാം:
1
2
3
4
5
6
7
8
9
10
11
12
13
| # This program tells if a given number is negative, zero, or # positive. The program demonstrates the use of the "if # ... else" program construct. number = input ( "Please input a number: " ) if number < 0 : print number, " is a negative number" else : if number = = 0 : print number, " is zero" else : print number, " is a positive number" |
ഈ പ്രോഗ്രാമില് പല അളവില് സ്പേസ് വിട്ട് വരികള് എഴുതിയിരിക്കുന്നത് ശ്രദ്ധിക്കുക. മുകളില്ക്കൊടുത്ത വിശദീകരണം അനുസരിച്ച് ഇത് മനസ്സിലാക്കാന് ശ്രമിക്കുക. സംശയമുണ്ടെങ്കില് ചോദിക്കുക.
ജനിച്ച വര്ഷം കണ്ടുപിടിക്കുന്നതെങ്ങനെ? രണ്ടാം പതിപ്പ്
ജോണ്, ഹരിമാരുടെ പ്രശ്നം പരിഹരിക്കുന്ന പ്രോഗ്രാം എഴുതാന് വേണ്ടത്ര പൈത്തണ് നാം പഠിച്ചുകഴിഞ്ഞു. പാഠത്തിന്റെ മൂന്നാം ഭാഗത്ത് കൊടുത്ത ലോജിക് ഒരു പ്രോഗ്രാമാക്കി ഒന്ന് എഴുതി നോക്കിയാലോ? ലോജിക് വിശദമായിത്തന്നെ നാം എഴുതിയതുകൊണ്ട് ഇത് പ്രോഗ്രാമാക്കുക എന്നത് തികച്ചും അനായാസം തന്നെ. കുറച്ചു വലിയ പ്രോഗ്രാമുകള് എഴുതാനുള്ള ഏറ്റവും എളുപ്പ വഴിയും ഇതു തന്നെയാണ്: ആദ്യം പ്രോഗ്രാമിന്റെ ലോജിക് നമുക്കിഷ്ടമുള്ള ഭാഷയില് എഴുതുക. പിന്നെ അതിന്റെ ഓരോ ഭാഗവും പൈത്തണിലേക്ക് മൊഴിമാറ്റം നടത്തുക. ഒരു വലിയ പ്രോഗ്രാം ഒറ്റയടിക്ക് പൈത്തണില് എഴുതുന്നതിലും എളുപ്പം — തെറ്റുകള് കുറയ്ക്കാനുള്ള എളുപ്പ വഴിയും — ഇങ്ങനെ ചെയ്യുന്നതാണ്.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
| # This program asks for the name and age in years and months # of the user, and outputs the year when the user was born. name = raw_input ( "Hello, what is your name? " ) print name, ", please tell me your age in years and months." years = input ( "How many years? " ) months = input ( "And how many months? " ) current_year = 2010 current_month = 8 if months < current_month : year_of_birth = current_year - years else : year_of_birth = current_year - years - 1 print name, ", you were born in " , year_of_birth print "Goodbye!" |
പ്രവര്ത്തനങ്ങള്
- പ്രവ. 3.
- ഈ പ്രോഗ്രാം ശ്രദ്ധിച്ച് വായിക്കുക. ഇത് പാഠത്തിന്റെ മൂന്നാം ഭാഗത്ത് കൊടുത്ത ലോജിക്കുമായി യോജിച്ചുപോകുന്നുണ്ടോ എന്ന് തിട്ടപ്പെടുത്തുക.
- പ്രവ. 4.
- ഈ പ്രോഗ്രാം പല തവണ പ്രവര്ത്തിപ്പിക്കുക. പല (വര്ഷം, മാസം) ജോടികള്ക്ക് ഇത് ശരിയായ ഉത്തരം തരുന്നുണ്ടോ എന്ന് പരിശോധിക്കുക.
- പ്രവ. 5.
- ഈ പ്രോഗ്രാം എപ്പോഴാണ് തെറ്റായ ഉത്തരം തരുന്നത്? മുന്പുള്ള പ്രോഗ്രാമിനെ അപേക്ഷിച്ച് ഈ പ്രോഗ്രാം തെറ്റായ ഉത്തരം തരുന്ന അവസരങ്ങള് കൂടുതലോ കുറവോ? ഈ തെറ്റിനെ ഒഴിവാക്കുന്ന രീതിയില് പ്രോഗ്രാം തിരുത്തിയെഴുതുക.
ബൂളിയന് സംകാരകങ്ങള്
ശരി, തെറ്റ് (
True, False
) എന്നീ രണ്ട് സ്ഥിരാങ്കങ്ങളെ ബൂളിയന് മൂല്യങ്ങള് (Boolean values)എന്ന് പറയുന്നു. ഈ രണ്ടു വിലകളെ അടിസ്ഥാനപ്പെടുത്തിയുള്ള ലോജിക് വികസിപ്പിച്ചെടുത്ത ഇംഗ്ളീഷ് ഗണിതശാസ്ത്രജ്ഞനായ ജോര്ജ് ബൂളിന്റെ
ബഹുമാനാര്ത്ഥമാണ് ഇത്. തുലന സംകാരകങ്ങള് പ്രയോഗിക്കുമ്പോള് കിട്ടുന്നത്
ബൂളിയന് മൂല്യങ്ങളാണല്ലോ. ഇത്തരത്തിലുള്ള മൂല്യങ്ങളെ സംയോജിപ്പിക്കാന്
ഉപയോഗിക്കുന്ന സംകാരകങ്ങളാണ് ബൂളിയന് സംകാരകങ്ങള് (Boolean operators).
പേരുകേട്ടാല് ഭയം തോന്നാമെങ്കിലും ഇവ വളരെ ലളിതങ്ങളായ സംഭവങ്ങളാണ്; ഈ
പേരിലല്ലെങ്കിലും ഇവയെ നമുക്കെല്ലാവര്ക്കും കുട്ടിക്കാലം മുതല്ക്കേ
പരിചയമുള്ളതാണുതാനും!പൈത്തണ് പ്രോഗ്രാമുകളില് ധാരാളമായി ഉപയോഗിക്കുന്ന ചില ബൂളിയന് സംകാരകങ്ങളുടെ പ്രയോഗം വ്യക്തമാക്കുന്ന പട്ടിക. ഇവിടെ
a, b
എന്നിവ True, False
എന്നീ വിലകളുള്ള സ്ഥിരാങ്കങ്ങളോ ചരങ്ങളോ ആകാം: ബൂളിയന് സംകാരകം | പ്രയോഗം | രണ്ടാം കോളത്തിലെ വ്യഞ്ജകത്തിന്റെ വില | |
---|---|---|---|
True ആകുന്നത് | False ആകുന്നത് | ||
not | not a | a യുടെ വില False ആണെങ്കില് | a യുടെ വില True ആണെങ്കില് |
and | a and b | a, b രണ്ടിന്റെയും വിലകള് True ആണെങ്കില് | a, b എന്നിവയില് ഒന്നിന്റെയെങ്കിലും വില False ആണെങ്കില് |
or | a or b | a, b എന്നിവയില് ഒന്നിന്റെയെങ്കിലും വില True ആണെങ്കില് | a, b രണ്ടിന്റെയും വിലകള് False ആണെങ്കില് |
ബൂളിയന് സംകാരകങ്ങളെക്കുറിച്ച് പ്രത്യേകം ശ്രദ്ധിക്കേണ്ടതായ ഒരു കാര്യം: മുകളിലെ പട്ടിക കണ്ടാല് തോന്നുന്നതിന്റെ പത്തിലൊന്ന് കാഠിന്യം ഇവ പ്രോഗ്രാമില് ഉപയോഗിക്കുമ്പോള് തോന്നുകയില്ല. and, or, not എന്നീ വാക്കുകള് ഇംഗ്ളീഷില് ഉപയോഗിക്കുന്നതുപോലെ തന്നെ പ്രോഗ്രാമിലും രണ്ടാമതൊന്ന് ആലോചിക്കാതെ ഉപയോഗിച്ചു പോവുകയാണ് പതിവ്. കുറച്ച് ഉദാഹരണങ്ങള് കൊണ്ട് ഇത് വ്യക്തമാകും. എപ്പോഴെങ്കിലും സംശയം വന്നാല് ഈ പട്ടിക നോക്കുകയും ചെയ്യാം.
തന്നിരിക്കുന്ന സംഖ്യ 2, 3, 5 ഇവ മൂന്നിന്റേയും ഗുണിതമാണോ എന്ന് പരിശോധിക്കുന്ന ഒരു പ്രോഗ്രാം എഴുതി നോക്കാം:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
| # This program tells if a given number is a multiple of 2, # 3, and 5. The program demonstrates the use of the "if # ... else" program construct. number = input ( "Please input a number: " ) if (number % 2 ) = = 0 : if (number % 3 ) = = 0 : if (number % 5 ) = = 0 : print number, " is a multiple of 2, 3, and 5" else : print number, " is not a multiple of 2, 3, and 5" else : print number, " is not a multiple of 2, 3, and 5" else : print number, " is not a multiple of 2, 3, and 5" |
പ്രവര്ത്തനം
- പ്രവ. 6.
-
ഈ പ്രോഗ്രാം ശ്രദ്ധിച്ച് വായിക്കുക. ഇവിടെ സ്പേസ് ഉപയോഗിച്ചിരിക്കുന്ന രീതി ശരിക്ക് മനസ്സിലായി എന്ന് ഉറപ്പുവരുത്തുക. ഓരോ
if
-ന്റെയുംelse
ഏതാണ്? ഈ പ്രോഗ്രാമിന്റെ ലോജിക് എന്താണ്?
ഇതേ പ്രശ്നത്തിന് ഉത്തരം തരുന്ന മറ്റൊരു പ്രോഗ്രാം നോക്കൂ. പല പ്രാവശ്യം "if ..." എന്നെഴുതുന്നതിനു പകരം ഇവിടെ "and" ഉപയോഗിച്ചിരിക്കുന്നു. ഫലമോ? മുമ്പത്തെ പ്രോഗ്രാമിന്റെയത്ര ദൈര്ഘ്യമില്ലാത്തതും വായിച്ചു മനസ്സിലാക്കാന് അത്രതന്നെ പ്രയാസപ്പെടേണ്ടാത്തതുമായ ഒരു പ്രോഗ്രാം. പ്രോഗ്രാമിലെ ഏഴാമത്തെ വരി അധികം വലത്തേക്ക് നീണ്ടു പോകാതിരിക്കാനായി (ബ്രൗസറില് വായിക്കാനുള്ള സൗകര്യത്തിനായി മാത്രം) "\" ഉപയോഗിച്ച് രണ്ടായി മുറിച്ചിരിക്കുന്നു:
1
2
3
4
5
6
7
8
9
10
11
| # This program tells if a given number is a multiple of 2, # 3, and 5. The program demonstrates the use of the "and" # boolean operator. number = input ( "Please input a number: " ) if (number % 2 ) = = 0 and (number % 3 ) = = 0 \ and (number % 5 ) = = 0 : print number, " is a multiple of 2, 3, and 5" else : print number, " is not a multiple of 2, 3, and 5" |
പ്രവര്ത്തനങ്ങള്
- പ്രവ. 7.
- തന്നിരിക്കുന്ന സംഖ്യ 2, 3, 5 ഇവയില് ഒന്നിന്റെയെങ്കിലും ഗുണിതമാണോ എന്ന് പരിശോധിക്കുന്ന ഒരു പ്രോഗ്രാം എഴുതുക. ഇതിനായി "or" എന്ന ബൂളിയന് സംകാരകം ഉപയോഗിക്കുക.
- പ്രവ. 8.
- ഏഴാം പ്രവര്ത്തനത്തിലെ അതേ പ്രശ്നത്തിനുള്ള പ്രോഗ്രാം "or" ഉപയോഗിക്കാതെ എഴുതുക.
ദ്വിമാന സമവാക്യത്തിന്റെ മൂലം കാണാനുള്ള ഒരു പ്രോഗ്രാം binudigitaleye എന്ന വായനക്കാരന് കമന്റായിട്ടത് ചെറിയ മാറ്റങ്ങളോടെ താഴെ എടുത്തെഴുതുന്നു. IDLE ഉപയോഗിച്ച് ഇത് പല പ്രാവശ്യം പ്രവര്ത്തിപ്പിച്ചു നോക്കുക, a, b, c എന്നിവയ്ക്ക് പല വിലകള് (ന്യൂനസംഖ്യകളും ദശാംശ സംഖ്യകളും ഉള്പ്പടെ) കൊടുത്തു നോക്കൂ. ശരിയായ ഉത്തരം കിട്ടുന്നുണ്ടോ?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
| # This program finds the roots of a quadratic equation using # the famous quadratic formula. It takes as input the # coefficients a, b, and c of the equation ax^2 + bx + c = 0 print " A program that finds the roots of the quadratic \ equation" print " ax^2+bx+c=0 where a is not 0" a = input ( "a = " ) b = input ( "b = " ) c = input ( "c = " ) # Find the value of the discriminant. d = b * * 2 - 4 * a * c if d < 0 : print "The equation does not have real roots." else : if d = = 0 : print " The two roots of the equation coincide." print " The single value of the roots is: " , \ - b / ( 2 * a) else : # Find the square root of d (how?) sqrt_d = d * * ( 1.0 / 2 ) print " One root of the equation is: " , \ ( - b + sqrt_d) / ( 2 * a) print " The other root is: " , ( - b - sqrt_d) / ( 2 * a) |
പ്രവര്ത്തനങ്ങള്
- പ്രവ. 9.
- (മിശ്ര സംഖ്യകളെ പരിചയമുള്ളവര്ക്ക് മാത്രം) ഈ പ്രോഗ്രാം രേഖീയ സംഖ്യകള് (real numbers) മൂലങ്ങളായി വരുന്ന ദ്വിമാന സമവാക്യങ്ങളെ മാത്രമെ ശരിയായി പരിഗണിക്കുന്നുള്ളൂ; മിശ്ര സംഖ്യകള് (complex numbers) മൂലങ്ങളായി വരുന്ന ദ്വിമാന സമവാക്യങ്ങളെ ഒഴുക്കന്മട്ടില് അവഗണിച്ചിരിക്കുകയാണ്. ഈ കുറവ് പരിഹരിക്കുക; (ഉദാഹരണമായി) a = 1, b = -2, c = 2 എന്ന ഇന്പുട്ട് കിട്ടിയാല് 1 + 1.0 i, 1 - 1.0 i എന്നീ ഉത്തരങ്ങള് തരുന്ന രീതിയില് പ്രോഗ്രാമിനെ മാറ്റുക.
കൂടുതല് പ്രവര്ത്തനങ്ങള്
if
-നെ പരിചയപ്പെട്ട നിലയ്ക്ക് ഇനി നമുക്ക് കൂടുതല്
രസകരങ്ങളായ പ്രവര്ത്തനങ്ങള് ചെയ്തു തുടങ്ങാം. പ്രോഗ്രാമിംഗ്
പ്രവര്ത്തനങ്ങള് ചെയ്യുമ്പോള് പ്രത്യേകം ശ്രദ്ധിക്കേണ്ടതായ ഒരു
കാര്യമുണ്ട്: വെറുതേ പ്രോഗ്രാം എഴുതിയതുകൊണ്ടു മാത്രം പ്രവര്ത്തനത്തിന്റെ ഫലം നമുക്ക് കിട്ടുന്നില്ല.
എഴുതിയ പ്രോഗ്രാമിന് ശരിയായ എന്ത് ഇന്പുട്ട് കൊടുത്താലും അത് ശരിയായ
ഉത്തരം തരും എന്ന് ഉറപ്പു വരുത്തണം. ഇതിനായി രണ്ടു കാര്യങ്ങള് ചെയ്യണം:- പ്രോഗ്രാം വളരെ ശ്രദ്ധയോടെ, വിമര്ശനബുദ്ധ്യാ വായിച്ചുനോക്കണം. നാമെഴുതിയ പ്രോഗ്രാം എന്തുകൊണ്ട് ശരിയാണ് എന്നല്ല നോക്കേണ്ടത്, മറിച്ച് അതിലെ തെറ്റ് എവിടെയാണ് എന്നാണ്. ഇങ്ങനെ കണിശതയോടെ സ്വന്തം പ്രോഗ്രാം വായിക്കാന് പഠിക്കുക എന്നത് തെറ്റില്ലാതെ പ്രോഗ്രാം എഴുതാന് ഒഴിച്ചുകൂടാനാവാത്ത ഒന്നാണ്.
- പ്രോഗ്രാമിന് പല തരത്തിലുള്ള ഇന്പുട്ടുകള് കൊടുത്ത് പ്രവര്ത്തിപ്പിച്ചുനോക്കണം. നാം തന്നെ എഴുതിയ പ്രോഗ്രാം ആയതുകൊണ്ട് അത് ശരിയായ ഉത്തരം തരുന്ന മട്ടിലുള്ള ഇന്പുട്ടുകള് കൊടുക്കാനാണ് നമുക്ക് സ്വതവേ തോന്നുക. എന്നാല് ഇങ്ങനെയല്ലാത്ത, പ്രോഗ്രാം തെറ്റിപ്പോകാന് സാധ്യതയുള്ള തരം ഇന്പുട്ടുകളും ആലോചിച്ചെടുത്ത് അവ പ്രോഗ്രാമിന് കൊടുത്തുനോക്കണം.
ഇതു വരെ പഠിച്ച പൈത്തണ് ഉപയോഗിച്ച് ചെയ്യാവുന്ന കുറച്ച് പ്രവര്ത്തനങ്ങള് ഇതാ:
പ്രവര്ത്തനങ്ങള്
താഴെപ്പറയുന്ന തരം പ്രോഗ്രാമുകള് എഴുതുക:- പ്രവ. 10.
-
- ഇന്പുട്ട്: ഒരു കുട്ടിയുടെ ഒരു വിഷയത്തിലുള്ള മാര്ക്ക്.
- ഔട്പുട്ട്: ആ കുട്ടിക്ക് ആ വിഷയത്തില് കിട്ടിയ ഗ്രേഡ്.
- പ്രവ. 11.
-
- ഇന്പുട്ട്: ഒരു മാസത്തിന്റെ ക്രമസംഖ്യ : 1 മുതല് 12 വരെയുള്ളത്. ഉദാ: 7
- ഔട്പുട്ട്: ആ മാസത്തിന്റെ പേര്. ഉദാ: July
- പ്രവ. 12.
-
- ഇന്പുട്ട്: ദിവസങ്ങളുടെ എണ്ണം : ഒരു പൂര്ണ്ണസംഖ്യ. ഉദാ: 375.
- ഔട്പുട്ട്: ഒരു വര്ഷത്തില് 365 ദിവസം എന്ന കണക്കില് ഇത്രയും ദിവസമെന്നാല് എത്ര വര്ഷം, ആഴ്ച, ദിവസം എന്നത്. ഉദാ: 375 days is 1 year, 1 week, and 3 days.
- പ്രവ. 13.
-
- ഇന്പുട്ട്: ഒരു വര്ഷം. ഉദാ: 1967.
- ഔട്പുട്ട്: തന്നിരിക്കുന്ന വര്ഷം അധിവര്ഷമാണോ (leap year) അല്ലയോ എന്നത്. ഉദാ: 1967 is not a leap year.
- പ്രവ. 14.
-
- ഇന്പുട്ട്: ഈ വര്ഷത്തിലെ ഒരു ദിവസം — വര്ഷം, മാസം, തീയതി എന്ന രീതിയില്.
- ഔട്പുട്ട്: തന്നിരിക്കുന്ന ദിവസത്തിന്റെ അടുത്ത ദിവസം — വര്ഷം, മാസം, തീയതി എന്ന രീതിയില്.
- പ്രവ. 15.
-
- ഇന്പുട്ട്: ഒരു ദിവസം — വര്ഷം, മാസം, തീയതി എന്ന രീതിയില്.
- ഔട്പുട്ട്: തന്നിരിക്കുന്ന ദിവസത്തിന്റെ അടുത്ത ദിവസം — വര്ഷം, മാസം, തീയതി എന്ന രീതിയില്.
- പ്രവ. 16.
-
- ഇന്പുട്ട്: മൂന്നു സംഖ്യകള്.
- ഔട്പുട്ട്: തന്നിരിക്കുന്നതില്വെച്ച് ഏറ്റവും വലിയ സംഖ്യ.
- പ്രവ. 17.
-
- ഇന്പുട്ട്: മൂന്നു സംഖ്യകള്.
- ഔട്പുട്ട്: തന്നിരിക്കുന്നതില്വെച്ച് ഏറ്റവും ചെറിയ സംഖ്യ.
പൈത്തണ്: പാഠം ആറ്
>> Thursday, September 2, 2010
ആമുഖം
1, 2, 3, ... മുതലായ, എണ്ണാനുപയോഗിക്കുന്ന സംഖ്യകളെയാണല്ലോ എണ്ണല്സംഖ്യകള് എന്നു വിളിക്കുന്നത്? "സംഖ്യ" എന്ന് വിളിക്കപ്പെടുന്നവയില് ഏറ്റവും ലളിതവും സുഗ്രാഹ്യവുമായവ എണ്ണല്സംഖ്യകളാണ്. എണ്ണല്സംഖ്യകളെ പരിചയമില്ലാത്ത മുതിര്ന്ന ഒരാള്പോലും ഉണ്ടാവില്ല; അക്ഷരമറിയാത്തവര്ക്കുപോലും എണ്ണല് അറിയുമായിരിക്കും. നമ്മുടെ സമൂഹത്തില് ജീവിച്ചുപോകണമെങ്കില് എണ്ണല് അറിയാതെ നിവൃത്തിയില്ല. നന്നേ ചെറുപ്രായത്തില്ത്തന്നെ മറ്റുള്ളവര് നമ്മെ എണ്ണാന് പഠിപ്പിക്കുന്നു. എന്തിന്റെയെങ്കിലുമൊക്കെ എണ്ണം ചോദിക്കുന്നത് കുട്ടികളോടുള്ള കൊഞ്ചലിന്റെതന്നെ ഭാഗമാണ്.
എണ്ണുന്നതിന്റെ അത്രത്തോളം തന്നെ ലളിതവും സ്വാഭാവികവുമാണ് നമ്മില് മിക്കവര്ക്കും സങ്കലനം — രണ്ടു സംഖ്യകള് കൂട്ടി ഒരു സംഖ്യയാക്കുക — എന്ന ക്രിയയും. സ്കൂളില് നന്നേ ചെറിയ ക്ളാസില്ത്തന്നെ ഇത് പഠിപ്പിക്കുന്നു. സംഖ്യകള് ശരിക്കു കൂട്ടാന് അറിയാതെ സ്കൂളില് "പഠിച്ച്" ഇറങ്ങുന്നവരും പുറംലോകത്ത് എന്തെങ്കിലുമൊക്കെ ജോലിചെയ്തു ജീവിച്ചുതുടങ്ങുമ്പോള് കൂട്ടലും കിഴിക്കലുമൊക്കെ തനിയേ പഠിച്ചുപോകുന്നു. എന്നാല് സങ്കലനത്തിന്റെ അത്രതന്നെ എളുപ്പമല്ല അടുത്ത ക്രിയയായ ഗുണനം — ചെറുപ്പത്തില് ഗുണനപ്പട്ടിക കാണാതെ പഠിക്കാന് പെട്ട പാടും കിട്ടിയ ശിക്ഷകളുമൊക്കെ നമ്മില് ചിലര്ക്കെങ്കിലും ഓര്മ്മകാണും. സംഖ്യകളെടുത്ത് പെരുമാറി — സ്കൂളിലെന്നതിലുപരി പുറത്ത്: മിക്കവാറും ക്രിക്കറ്റില് സ്കോര് ഗണിച്ചെടുത്തും മറ്റും — കുറേ പരിചയം വരുമ്പോള് ഗുണനത്തെ ആവര്ത്തിച്ചുള്ള സങ്കലനമായി കാണാന് നാം അറിയാതെ പഠിക്കുന്നു.
ഗുണനമെന്നാല് ആവര്ത്തിച്ചുള്ള സങ്കലനമാണെങ്കിലും രണ്ടിന്റെയും സ്വഭാവങ്ങള്തമ്മില് കാതലായ വ്യത്യാസങ്ങളുണ്ട്. ഉദാഹരണമായി, നാലോ അതിലധികമോ ആയ ഏത് എണ്ണല്സംഖ്യയെയും മറ്റുരണ്ട് എണ്ണല്സംഖ്യകളുടെ തുകയായി ഒന്നിലധികം രീതിയില് എഴുതാം. അതായത്,
- 4 = 1 + 3 = 2 + 2
- 5 = 1 + 4 = 2 + 3
- 10 = 1 + 9 = 2 + 8 = 3 + 7 = 4 + 6 = 5 + 5
അഭാജ്യസംഖ്യകള്
16-നെ 16 = 1 x 16 = 2 x 8 = 4 x 4 എന്നിങ്ങനെ ഗുണിതങ്ങളായി എഴുതാമല്ലോ. 1, 2, 4, 8, 16 എന്നിവയെ 16-ന്റെ ഘടകങ്ങള് (factors) എന്ന് വിളിക്കുന്നു. ഇതുപോലെ 21-നെ 21 = 1 x 21 = 3 x 7 എന്നിങ്ങനെ എഴുതാം; 1, 3, 7, 21 എന്നിവയാണ് 21-ന്റെ ഘടകങ്ങള്. ഏത് എണ്ണല്സംഖ്യയുടെയും ഘടകമായി 1-ഉം ആ സംഖ്യതന്നെയും ഉണ്ടാവും എന്ന് കുറച്ചൊന്നാലോചിച്ചാല് മനസ്സിലാകും — 1-നെ അതിനോടുതന്നെ പല പ്രാവശ്യം കൂട്ടി ഏത് എണ്ണല്സംഖ്യയിലും എത്തിക്കാം; ഏത് എണ്ണല്സംഖ്യയും "ഒരു പ്രാവശ്യം കൂട്ടിയാല്" ആ സംഖ്യതന്നെയാണുതാനും.
കൃത്യം രണ്ടു ഘടകങ്ങള് ഉള്ള സംഖ്യകളെ — മേല്പ്പറഞ്ഞതില്നിന്ന് ഈ ഘടകങ്ങള് 1-ഉം ആ സംഖ്യതന്നെയും ആയിരിക്കും എന്നത് വ്യക്തമാണ് — അഭാജ്യസംഖ്യകള് അല്ലെങ്കില് അഭാജ്യങ്ങള് എന്ന് വിളിക്കുന്നു. ഉദാഹരണത്തിന് 2, 3, 5, 7 എന്നിവ അഭാജ്യങ്ങളാണ്. 2 = 1 x 2, 3 = 1 x 3, 5 = 1 x 5, 7 = 1 x 7 എന്നിങ്ങനെ നിസ്സാരമായ (trivial) ഒരേ ഒരു രീതിയിലല്ലാതെ ഈ സംഖ്യകളെ ഗുണനഫലങ്ങളായി എഴുതാന് പറ്റില്ലല്ലോ. വേറൊരു രീതിയില് നോക്കിയാല്, ഇവയെ നിസ്സാരമായ രീതിയിലല്ലാതെ ഒരേ പൂര്ണ്ണസംഖ്യാവലുപ്പമുള്ള ഭാഗങ്ങളായി "മുറിക്കാന്" പറ്റില്ല. ഉദാഹരണത്തിന്, അഞ്ച് മാങ്ങകളെ ഒരു മാങ്ങ വീതമുള്ള അഞ്ച് കൂട്ടങ്ങളാക്കാം; ഒരേ എണ്ണം വീതമുള്ള പല കൂട്ടങ്ങളാക്കാന് മറ്റൊരു രീതിയിലും പറ്റില്ല. "അഭാജ്യം" എന്ന പേരിന് കാരണവും ഇതുതന്നെ. നൂറിനെക്കാള് ചെറുതായ അഭാജ്യങ്ങളെ താഴെ എടുത്തെഴുതുന്നു.
നൂറില് താഴെയുള്ള അഭാജ്യങ്ങള് 2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97
ഇങ്ങനെയൊരു പട്ടിക നമുക്കെങ്ങനെയുണ്ടാക്കാം? 1 മുതല് 100 വരെയുള്ള സംഖ്യകള് ഓരോന്നും അഭാജ്യമാണോ എന്ന് നോക്കിയാല് മതി. 2 ഒഴികെയുള്ള ഇരട്ടസംഖ്യകളൊന്നും തന്നെ അഭാജ്യങ്ങളല്ലാത്തതുകൊണ്ട് 1 മുതല് 100 വരെയുള്ളതില് പകുതി സംഖ്യകളെപ്പറ്റി അധികം പ്രയാസപ്പെടാതെതന്നെ നമുക്കൊരു തീരുമാനമുണ്ടാക്കാം : 2-നെ പട്ടികയില് പെടുത്തണം, മറ്റ് ഇരട്ടസംഖ്യകളൊന്നുംതന്നെ പട്ടികയില് വേണ്ട. ഇനി ബാക്കിയുള്ള അമ്പത് ഒറ്റ സംഖ്യകളെപ്പറ്റി മാത്രം ആലോചിച്ചാല് മതി. ഇവയില് 1-നെ പട്ടികയില് വേണ്ട, 3, 5, 7 എന്നിവയെ വേണം. അവശേഷിക്കുന്ന ഒറ്റസംഖ്യകളില് 3-ന്റെയും 5-ന്റെയും ഗുണിതങ്ങളെ നമുക്ക് വേഗം തിരിച്ചറിഞ്ഞ് ഒഴിവാക്കാം (എങ്ങനെ?). ബാക്കിയുള്ള ഒറ്റസംഖ്യകളുടെ കാര്യമാണ് അത്ര എളുപ്പം കിട്ടാത്തത്. ഉദാഹരണത്തിന്, 67-നെ അതിനെക്കാള് ചെറിയ ഏതെങ്കിലും സംഖ്യകൊണ്ട് പൂര്ണ്ണമായും ഹരിക്കാമോ എന്ന് എങ്ങനെ കണ്ടുപിടിക്കും? ഹരിച്ചുനോക്കുകയേ നിവൃത്തിയുള്ളൂ (എനിക്കറിയാവുന്നിടത്തോളം). ഇങ്ങനെ കുറച്ചു കഷ്ടപ്പെട്ടാല് മേല്ക്കൊടുത്ത പട്ടികയുണ്ടാക്കാം.
ഇനി 100 മുതല് 200 വരെയുള്ള അഭാജ്യങ്ങളേതാണെന്ന് ചോദിച്ചാലോ? 1000 വരെയുള്ളതാണെങ്കിലോ? ഇതേ രീതിയില്ത്തന്നെ കണ്ടുപിടിക്കണം. ഓരോ പുതിയ സംഖ്യയും അഭാജ്യമാണോ എന്ന് നോക്കാനുള്ള ബുദ്ധിമുട്ട് ഏറിയേറി വരും. എവിടെയെങ്കിലും ഒരു തെറ്റുവരുത്താനുള്ള സാധ്യത നല്ലതുപോലെയുണ്ടുതാനും. ചുരുക്കിപ്പറഞ്ഞാല്, ലളിതമായ എന്നാല് മടുപ്പിക്കുന്ന പണിക്കുള്ള നല്ല ഒരുദാഹരണം. കംപ്യൂട്ടറിന് ഏറ്റവും ശോഭിക്കാവുന്നതും ഇങ്ങനെയുള്ള കാര്യങ്ങളിലാണ്. മുകളിലെ പട്ടിക ഞാന് മെനക്കെട്ട് കണ്ടുപിടിച്ചതല്ല. മുകളില് വിവരിച്ച അതേ ലോജിക് അനുസരിച്ചുള്ള ഒരു പ്രോഗ്രാം എഴുതി കംപ്യൂട്ടറിനെക്കൊണ്ട് ചെയ്യിച്ചതാണ്. ഈ പ്രോഗ്രാം ഉപയോഗിച്ച് അഭാജ്യങ്ങളുടെ പട്ടികയുണ്ടാക്കാന് കംപ്യൂട്ടര് വളരെക്കുറച്ച് സമയമേ എടുത്തുള്ളൂ: സെക്കന്റിന്റെ പത്തിലൊരംശമോ മറ്റോ. അതായത്, നാം ഈ പട്ടിക വായിക്കാന് എടുക്കുന്ന സമയത്തിന്റെ നൂറിലൊരംശമോ അതില് കുറവോ മാത്രം.
ഇതേ പ്രോഗ്രാമില് ചെറിയ മാറ്റങ്ങള് വരുത്തി 100 മുതല് 200 വരെയുള്ള അഭാജ്യങ്ങള് കണ്ടുപിടിച്ചത് ഇതാ:
നൂറിനും ഇരുനൂറിനും ഇടയ്ക്കുള്ള അഭാജ്യങ്ങള് 101 103 107 109 113 127 131 137 139 149 151 157 163 167 173 179 181 191 193 197 199
ഒരു പൂര്ണ്ണസംഖ്യ അഭാജ്യമാണോ എന്ന് പ്രോഗ്രാമെഴുതി എങ്ങനെ കണ്ടുപിടിക്കാം? ഏറ്റവും ലളിതമായ വഴി ആ സംഖ്യയെക്കാള് ചെറുതും 1-നെക്കാള് വലുതുമായ ഏതെങ്കിലും പൂര്ണ്ണസംഖ്യകൊണ്ട് അതിനെ നിശ്ശേഷം (നിശ്ശിഷ്ടം?) ഹരിക്കാമോ എന്ന് നോക്കുക എന്നതാണ്. ഉദാഹരണത്തിന് 5 അഭാജ്യമാണോ എന്ന് നോക്കുന്ന പ്രോഗ്രാം ഇതാ:
1234if
5
%
2
=
=
0
or
5
%
3
=
=
0
or
5
%
4
=
=
0
:
print
"5 is not a prime"
else
:
print
"5 is a prime"
പ്രവര്ത്തനങ്ങള്
- പ്രവ. 1.
- ഈ പ്രോഗ്രാം പ്രവര്ത്തിപ്പിച്ചുനോക്കുക. ഇത് ശരിയായ ഉത്തരം തരുന്നുണ്ടോ? ഈ പ്രോഗ്രാം പ്രവര്ത്തിക്കുന്നതെങ്ങനെ എന്ന് മനസ്സിലാക്കുക.
- പ്രവ. 2.
- ഇതേ രീതിയില് 15 അഭാജ്യമാണോ എന്ന് കണ്ടുപിടിക്കുന്ന പ്രോഗ്രാം എഴുതി പ്രവര്ത്തിപ്പിച്ചുനോക്കുക.
ഈ പ്രോഗ്രാമിന് എന്താണു കുഴപ്പം?
രണ്ടു പ്രവര്ത്തനങ്ങളും ചെയ്തുനോക്കിയാല് മുകളിലെ ഉദാഹരണത്തിന് എന്താണ് കുഴപ്പമെന്ന് മനസ്സിലാകും. ഒരു വലിയ സംഖ്യ (ഉദാ: 1234787) അഭാജ്യമാണോ എന്ന് ഈ രീതിയില് പ്രോഗ്രാമെഴുതി കണ്ടുപിടിക്കുന്ന കാര്യം ആലോചിച്ചുനോക്കൂ. പേജുകണക്കിന് വരുന്ന വളരെ വലിയ ഒരു പ്രോഗ്രാമായിരിക്കും അത്. ചില സംഖ്യകളൊക്കെ എഴുതാന് വിട്ടുപോകുന്നതുവഴി പ്രോഗ്രാമില് തെറ്റുവരാനുള്ള സാധ്യതയും കൂടുതലാണ്. 101 മുതല് 200 വരെയുള്ള അഭാജ്യസംഖ്യകള് ഏതൊക്കെയാണെന്ന് കണ്ടുപിടിക്കാന് ഇങ്ങനെ പ്രോഗ്രാമെഴുതണമെങ്കില് ഒരു ദിവസം മുഴുവന് ഇരുന്നെഴുതേണ്ടിവരും; എഴുതിക്കഴിഞ്ഞാലും അത് ശരിയാണോ എന്ന് നമുക്ക് വലിയ ഉറപ്പൊന്നും കാണുകയുമില്ല — ഏതെങ്കിലുമൊക്കെ സംഖ്യകള്കൊണ്ട് ഹരിച്ചാലുള്ള ശിഷ്ടം പൂജ്യമാണോ എന്നുനോക്കാന് ഇടയ്ക്കെങ്ങാനും വിട്ടുപോയിട്ടില്ല എന്ന് എങ്ങനെ ഉറപ്പിക്കും?
1234787 അഭാജ്യമാണ്. ഈ പാഠം പഠിച്ച് ഇതിലെ പ്രവര്ത്തനങ്ങള് ചെയ്തുകഴിയുമ്പോഴേക്കും ഏതു സംഖ്യയും അഭാജ്യമാണോ എന്ന് പരിശോധിക്കുന്ന പ്രോഗ്രാമെഴുതാന് നാം പഠിച്ചിരിക്കും.
നമ്മുടെ പ്രോഗ്രാമിന്റെ ലോജിക്കിനെപ്പറ്റി നമുക്ക് ഒന്നുകൂടി ഒന്ന് ആലോചിച്ചുനോക്കാം. 1-നെക്കാള് വലുതും, തന്നിരിക്കുന്ന സംഖ്യയെക്കാള് ചെറുതുമായ ഓരോ പൂര്ണ്ണസംഖ്യയെക്കൊണ്ടും തന്നിരിക്കുന്ന സംഖ്യയെ ഹരിച്ചാല് കിട്ടുന്ന ശിഷ്ടം പൂജ്യമാണോ എന്ന് നോക്കുക എന്നതാണ് പ്രോഗ്രാം ചെയ്യുന്നത്. ഇങ്ങനെ വലിയൊരുകൂട്ടം സംഖ്യകളെടുത്ത് പെരുമാറേണ്ടതുകൊണ്ടാണ് പ്രോഗ്രാമിന്റെ വലുപ്പം (അതെഴുതാനെടുക്കുന്ന സമയവും) തന്നിരിക്കുന്ന സംഖ്യ വലുതാകുന്തോറും വലുതായിക്കൊണ്ടേയിരിക്കുന്നത്. ഈ പ്രശ്നം പരിഹരിക്കാന് (മറ്റനേകം ഉപയോഗങ്ങള്ക്കും) പൈത്തണില് ലഭ്യമായ ഒരു ഉപാധിയാണ്
range()
.range()
പൈത്തണില് സംഖ്യകളുടെ സമാന്തരശ്രേണികള് (arithmetic progressions) നിര്മ്മിക്കാനുള്ള ഒരു ഉപാധിയാണ് range()
.
ഇതെന്താണെന്ന് മനസ്സിലാക്കാനുള്ള ഏറ്റവും എളുപ്പ വഴി (പ്രോഗ്രാമിംഗില്
മറ്റു മിക്ക കാര്യങ്ങള്ക്കുമെന്നതുപോലെ) ഇതിന്റെ പെരുമാറ്റം എങ്ങനെയാണ്
എന്ന് നോക്കുകയാണ്. പൈത്തണ് ഷെല് (IDLE-ലോ അല്ലാതെയോ) തുറന്ന്
താഴെക്കാണുന്ന പ്രോഗ്രാം ശകലങ്ങള് ഓരോന്നായി പരീക്ഷിച്ചുനോക്കുക:range ( 10 ) |
range ( 25 ) |
range ( 1027 ) |
range()
-ന്റെ ഒരു ഉപയോഗം മനസ്സിലായല്ലോ. പൂജ്യം മുതല് സൂചിപ്പിച്ച സംഖ്യയ്ക്ക് തൊട്ടുമുമ്പുവരെയുള്ള പൂര്ണ്ണസംഖ്യകളുടെ ഒരു ശ്രേണി range()
നമുക്ക് [, ] എന്നീ ചതുര ബ്രായ്ക്കറ്റുകള്ക്കുള്ളിലായി തരുന്നു. ഇങ്ങനെ
ചതുര ബ്രായ്ക്കറ്റുകള്ക്കുള്ളില് അര്ധവിരാമം (കോമ : , ) ഉപയോഗിച്ച്
വേര്തിരിച്ച് മൂല്യങ്ങള് എഴുതുന്നതിന് ലിസ്റ്റ് – list – എന്നതാണ്
പൈത്തണിലെ സാങ്കേതികപദം. range()
മേല്ക്കാണിച്ചതുപോലെ ഉപയോഗിച്ച് പൂജ്യം മുതല് ഏത് നിശ്ചിത സംഖ്യ വരെയുമുള്ള പൂര്ണ്ണസംഖ്യകളുടെ ലിസ്റ്റുകള് നമുക്കുണ്ടാക്കാം. range()
-ന് വേറെയും ചില കഴിവുകളുണ്ട്. ഇവയെന്താണെന്ന് മനസ്സിലാക്കാന് താഴെക്കാണുന്നവ പരീക്ഷിച്ചുനോക്കുക: range ( 1 , 10 ) |
range ( 7 , 25 ) |
range ( 1 , 10 , 2 ) |
range ( 7 , 25 , 3 ) |
range ( - 100 , 100 , 2 ) |
range ( 99 , - 100 , - 3 ) |
ഓരോ പ്രാവശ്യവും ഏറ്റവും അവസാനം വരുന്ന സംഖ്യ ഏതാണെന്ന് പ്രത്യേകം ശ്രദ്ധിക്കുക.
പ്രവര്ത്തനം
- പ്രവ. 3.
- താഴെക്കൊടുത്തിരിക്കുന്ന പ്രോഗ്രാം ശകലങ്ങളുടെ ഔട്പുട്ട്
എന്തായിരിക്കും എന്ന് ഊഹിച്ചുനോക്കുക. ഊഹം കൃത്യമാണോ എന്ന്
പരീക്ഷിച്ചുനോക്കുക.
range
(
17
)
range
(
0
,
-
10
,
-
1
)
range
(
0
,
-
10
,
1
)
range
(
0
,
65
,
7
)
range
(
10
,
10
)
ഒരു സംഖ്യ — ഉദാഹരണത്തിന് 67 — അഭാജ്യമാണോ എന്നറിയാന് നമ്മുടെ പ്രോഗ്രാം 2 മുതല് 66 വരെയുള്ള ഏതെങ്കിലും പൂര്ണ്ണസംഖ്യകൊണ്ട് 67-നെ നിശ്ശിഷ്ടം ഹരിക്കാന് പറ്റുമോ എന്ന് നോക്കുന്നു. അതായത്
range(2, 67)
തരുന്ന ലിസ്റ്റിലുള്ള ഓരോ സംഖ്യകൊണ്ടും 67-നെ ഹരിച്ചുനോക്കുന്നു. range(2, 67)
എന്ന് പ്രോഗ്രാമില് പറഞ്ഞാല് [2,3, ... , 66]
എന്ന ഈ ലിസ്റ്റ് നമുക്ക് കിട്ടും. എന്നാല് ഈ ലിസ്റ്റിലുള്ള സംഖ്യകള്
ഓരോന്നായി എങ്ങനെ കൈയ്യില്ക്കിട്ടും? ഇങ്ങനെ ഓരോന്നായി കിട്ടിയാലല്ലേ
ഓരോന്നുകൊണ്ടും ഹരിച്ചുനോക്കാന് കഴിയൂ? ഒരു ലിസ്റ്റിലുള്ള മൂല്യങ്ങളെ
ഓരോന്നായി എടുത്ത് പ്രയോഗിക്കാന് പാകത്തില് നമുക്കു തരുന്ന പൈത്തണ്
ഭാഷാപ്രയോഗമാണ് for
.ലിസ്റ്റുകളും for-ഉം
മുമ്പു പറഞ്ഞതുപോലെ, [, ] എന്നീ ബ്രായ്ക്കറ്റുകള്ക്കുള്ളിലായി മൂല്യങ്ങളെ കോമയിട്ട് വേര്തിരിച്ച് എഴുതുന്നതിനെയാണ് പൈത്തണില് ലിസ്റ്റ് എന്ന് വിളിക്കുന്നത്. വളരെ ലളിതമായ ഒരു ആശയമാണ് ഇതെങ്കിലും പ്രോഗ്രാം എഴുതുന്നതില് വളരെയധികം ഉപയോഗപ്പെടുന്ന ഒന്നാണ് ലിസ്റ്റ്. ഒന്നാലോചിച്ചാല് ഇതില് വലിയ അത്ഭുതമൊന്നുമില്ല: ദൈനംദിന ജീവിതത്തിലും വിവരങ്ങള് സൂക്ഷിച്ചുവെയ്ക്കാന് നാമുപയോഗിക്കുന്ന ചുരുക്കം ചില ഉപാധികളില് പ്രധാനപ്പെട്ടതാണ് ലിസ്റ്റ്. കടയില് നിന്ന് വാങ്ങേണ്ട സാധനങ്ങള്, ഫോണ് നമ്പരുകള് (ഡയറിയിലായാലും മൊബൈല് ഫോണിലായാലും), കല്ല്യാണത്തിനു വിളിക്കേണ്ട ആളുകളുടെ വിവരങ്ങള്, എന്നിങ്ങനെ ഒന്നിലധികം വിവരങ്ങള് ഉള്ള മിക്കയിടത്തും അവയെ നാം ലിസ്റ്റായി ആണ് രേഖപ്പെടുത്താറ്. ലിസ്റ്റല്ലാതെ ഈ ആവശ്യത്തിന് ഉപയോഗിച്ച് കണ്ടുവരുന്ന ഏക ഉപാധി പട്ടിക (table) ആണ്. ഇതാകട്ടെ ഓഫീസുകളിലോ പഠനസംബന്ധിയായ പ്രമാണങ്ങളിലോ മാത്രമേ കാണാറുള്ളൂ: ഔപചാരികമല്ലാത്ത കാര്യങ്ങള്ക്ക് പട്ടികകള് ഉപയോഗിക്കാറില്ലെന്നുതന്നെ പറയാം.
പൈത്തണില് ഒരു ലിസ്റ്റ് ഉണ്ടാക്കാന് ചെയ്യേണ്ടത് ഇത്രമാത്രം: ലിസ്റ്റില് വരേണ്ട മൂല്യങ്ങളെ കോമകൊണ്ട് വേര്തിരിച്ച് [, ] എന്നീ ബ്രായ്ക്കറ്റുകള്ക്കുള്ളിലായി എഴുതുക. കുറച്ച് ഉദാഹരണങ്ങള്:
-
['Bhama', 'Hari', 'Nizar', 'John',]
-
[1, 'Thiruvananthapuram', 2, 'Kollam', 3, 'Pathanamthitta']
-
[1, ['a', 'b', 'c'], 'd']
-
range()
സമാന്തരശ്രേണികളെ ഇങ്ങനെ ലിസ്റ്റ് രൂപത്തില് തരുന്നത് മുകളില് കണ്ടല്ലോ.
for
. ഇതിന്റെ ഉപയോഗം എങ്ങനെയാണെന്നറിയാന് താഴെക്കാണുന്ന പ്രോഗ്രാമുകള് പരീക്ഷിച്ചുനോക്കുക.
1
2
3
4
| print range ( 0 , 10 ) for number in range ( 0 , 10 ) : print 'Hello!' |
1
2
| for number in range ( 0 , 10 ) : print number |
1
2
3
4
5
6
| for name in [ 'John' , 'Vijayan' , 'Muraleekrishnan' , \ 'Muraleedharan' , 'Lalitha' , 'Sathyabhama' , 'Shemi' ,\ 'Sreenadh' , 'Sankaran' , 'Ramanunni' , 'Revi' , 'Nidhin' ,\ 'Hari' , 'Nizar' , 'Janardanan' , 'Jomon' ] : print name, ' is a member of the Maths Blog Team' |
1
2
3
| for number in range ( 1 , 50 ) : if (number % 2 ) = = 0 : print number, " is an even number." |
1
2
3
4
5
| sum = 0 for number in range ( 1 , 100 ) : sum = sum + number print 'The sum of the integers from 1 to 99 is ' , sum |
1
2
3
4
5
6
| sum = 0 for number in range ( 1 , 100 ) : if (number % 2 ) = = 1 : sum = sum + number print 'The sum of the odd integers from 1 to 99 is ' , sum |
for-നെപ്പറ്റി വിശദമായി
for
പ്രോഗ്രാമില് ഉപയോഗിക്കുന്ന വിധം നമുക്ക് കുറച്ചുകൂടി വിശദമായി പരിശോധിക്കാം: -
for
വരിയുടെ (ലഘുവായ) വ്യാകരണം ഇതാണ്:for variable in list :
. പേരുസൂചിപ്പിക്കുന്നതുപോലെ ഇവിടെvariable
എന്നത് ഒരു ചരവുംlist
എന്നത് ഒരു ലിസ്റ്റുമാണ്. ഉദാഹരണങ്ങളില് കാണുന്നതുപോലെ ലിസ്റ്റ് എന്നത് ഇവിടെ [, ] എന്നിവ ഉപയോഗിക്കുന്ന അക്ഷരാര്ത്ഥത്തിലുള്ള ഒരു ലിസ്റ്റോ, അതല്ലെങ്കില് ഒരു ലിസ്റ്റ് മൂല്യമായി കിട്ടുന്ന ഒരു വ്യഞ്ജകമോ (expression) — ഉദാഹരണം:range()
-ന്റെ ഏതെങ്കിലും പ്രയോഗം — ആകാം.list
കഴിഞ്ഞുള്ള:
പ്രത്യേകം ശ്രദ്ധിക്കുക. -
for
വരി കഴിഞ്ഞുവരുന്ന വരികളില്for
-ന്റെ പരിധിയില്പ്പെടുന്ന വരികള് (ഒന്നോ അതിലധികമോ) എഴുതണം. ഇങ്ങനെയുള്ള വരികള് എല്ലാം തന്നെ ഈfor
വരിയെ അപേക്ഷിച്ച് ഒരു നിശ്ചിത അകലം വലതുവശത്തേക്ക് മാറി ആയിരിക്കണം തുടങ്ങേണ്ടത്. - മുകളിലെ ഉദാഹരണങ്ങളില് നാലു സ്പേസ് വലത്തേക്ക് മാറിയാണ് എഴുതിയിട്ടുള്ളത്. ഇങ്ങനെ നാലു സ്പേസ് വിട്ടെഴുതുന്നതാണ് പൈത്തണ് മാനകം (standard).
- IDLE ഉപയോഗിച്ച് പ്രോഗ്രാം എഴുതുകയാണെങ്കില്
:
എന്നെഴുതി Enter അമര്ത്തുമ്പോള് IDLE തനിയെ തന്നെ എഴുതിത്തുടങ്ങാനുള്ള സൂചകം (cursor) പുതിയ വരിയില് നാലു സ്പേസ് വലത്തേക്ക് മാറ്റിത്തരുന്നത് കാണാം. ഇതൊന്ന് പരീക്ഷിച്ചു നോക്കൂ! ഇങ്ങനെ മാറുന്നില്ലെങ്കില് തൊട്ടുമുമ്പത്തെ വരിയുടെ വ്യാകരണം തെറ്റിയതാവും കാരണം. മിക്കവാറും ഇത് അവസാനം കൊടുക്കേണ്ടതായ:
വിട്ടുപോയതുകൊണ്ടാവും. -
list
എന്ന ലിസ്റ്റില് എത്ര അംഗങ്ങളുണ്ടോ, അത്രയും തവണfor
-ന്റെ പരിധിയില്പ്പെടുന്ന വരികളെല്ലാം പ്രവര്ത്തിപ്പിക്കുക എന്നതാണ്for
-ന്റെ അടിസ്ഥാന സ്വഭാവം. മുകളില് ആദ്യത്തെ ഉദാഹരണം പ്രവര്ത്തിപ്പിച്ചു നോക്കിയാല് ഇത് വ്യക്തമായി മനസ്സിലാകും. - ഇങ്ങനെ
for
-ന്റെ പരിധിയില്പ്പെടുന്ന വരികള് ഓരോ തവണ പ്രവര്ത്തിപ്പിക്കുമ്പോഴുംvariable
എന്ന ചരത്തിന്റെ വിലlist
എന്ന ലിസ്റ്റിലെ ഓരോ അംഗത്തിന്റെയും വിലയായി ക്രമത്തില് തനിയെ മാറുന്നു:
- ആദ്യത്തെ തവണ പ്രവര്ത്തിപ്പിക്കുമ്പോള്
variable
-ന്റെ വില ലിസ്റ്റിലെ ആദ്യത്തെ അംഗത്തിന്റെ വിലയാണ്. - രണ്ടാമത്തെ തവണ പ്രവര്ത്തിപ്പിക്കുമ്പോള്
variable
-ന്റെ വില ലിസ്റ്റിലെ രണ്ടാമത്തെ അംഗത്തിന്റെ വിലയാണ്. - മൂന്നാമത്തെ തവണ പ്രവര്ത്തിപ്പിക്കുമ്പോള്
variable
-ന്റെ വില ലിസ്റ്റിലെ മൂന്നാമത്തെ അംഗത്തിന്റെ വിലയാണ്. - അങ്ങനെയങ്ങനെ ...
- ആദ്യത്തെ തവണ പ്രവര്ത്തിപ്പിക്കുമ്പോള്
-
for
-ന്റെ പരിധിയില്പ്പെടുന്ന വരികളില്variable
എന്ന ചരത്തിനെ ക്രിയകളിലും മറ്റും ചരങ്ങള് സാധാരണ ഉപയോഗിക്കുന്നതുപോലെ ഉപയോഗിക്കാം. നാലു മുതല് ആറു വരെ ഉദാഹരണങ്ങള് പ്രവര്ത്തിപ്പിച്ചുനോക്കിയാല് ഇത് വ്യക്തമാകും. -
for
-ന്റെ പരിധിയില് വരേണ്ടുന്ന — ലിസ്റ്റിലെ അംഗങ്ങളുടെ എണ്ണത്തിന്റെ അത്രതവണ പ്രവര്ത്തിപ്പിക്കേണ്ടുന്ന — വരികള് എഴുതിക്കഴിഞ്ഞാല് പിന്നീടുള്ള വരിfor
വരി തുടങ്ങുന്ന അതേ അകലം ഇടതുവശത്തുനിന്ന് വിട്ട് വേണം തുടങ്ങാന്. അതായത്, നാലു സ്പേസ് വലത്തേക്ക് മാറി എഴുതുന്നത് നിര്ത്തണം എന്നര്ത്ഥം.for
-ന്റെ പരിധിയില്പ്പെടുന്ന വരികള് ഏതൊക്കെയാണെന്ന് പൈത്തണ് മനസ്സിലാക്കുന്നത്for
-നു ശേഷവുംfor
-ന്റെ അതേ നിരപ്പിലുള്ള ആദ്യത്തെ വരി കാണുന്നതിന് മുന്പും നാലു സ്പേസ് വലത്തേക്ക് മാറി വരുന്ന വരികള് ഏതൊക്കെയാണ് എന്ന് നോക്കിയിട്ടാണ്. അഞ്ചും ആറും ഉദാഹരണങ്ങള് പ്രവര്ത്തിപ്പിച്ചുനോക്കിയാല് ഇത് വ്യക്തമാകും. - ഇവിടെ നാലു സ്പേസ് എന്ന് പറഞ്ഞയിടത്തൊക്കെ അതിനു പകരം വേറെ ഏതെങ്കിലും ഒരു നിശ്ചിത അകലം ഇതേ ആവശ്യത്തിന് ഉപയോഗിക്കാം. ഉദാഹരണത്തിന്, ഒരു ടാബ് (കംപ്യൂട്ടറിന്റെ Tab കീ അമര്ത്തിയാല് കിട്ടുന്നത്) ഇതിനായി ഉപയോഗിക്കാം. ഒരേ പ്രോഗ്രാമില് ടാബുകളും സ്പേസുകളും രണ്ടുംകൂടി ഈ ആവശ്യത്തിന് ഉപയോഗിക്കരുത്. ഈ ആവശ്യത്തിന് നാലു സ്പേസ് ഉപയോഗിക്കുന്നതാണ് നല്ല പൈത്തണ് ശൈലിയായി കണക്കാക്കുന്നത്.
- ഇക്കാര്യങ്ങളിലെല്ലാം മുമ്പത്തെ പാഠത്തില് നാം പരിചയപ്പെട്ട
if
-ന്റെ ഘടനയുമായുള്ള സാമ്യം ശ്രദ്ധിക്കുക. - നാലും ആറും ഉദാഹരണങ്ങളില്
for
-ന്റെ പരിധിക്കുള്ളില്if
ഉപയോഗിച്ചിരിക്കുന്നത് ശ്രദ്ധിക്കുക. പൊതുവേ പറഞ്ഞാല്if, for
എന്നിവയുടെ പരിധിക്കുള്ളില് ഇങ്ങനെ എന്തുവേണമെങ്കിലും എത്രവേണമെങ്കിലും "ആഴത്തില്" എഴുതാം. ഇങ്ങനെ എഴുതുമ്പോള് സ്പേസ് കൊടുക്കുന്ന കാര്യത്തില് ഇതുവരെ പറഞ്ഞ (ലളിതങ്ങളായ) നിയമങ്ങള് പാലിച്ചിരിക്കണമെന്ന് മാത്രം : പുതിയ ഒരു പരിധി തുടങ്ങുമ്പോള് നാലു സ്പേസ് വലത്തേക്ക് മാറി എഴുതിത്തുടങ്ങുക. ഈ പരിധി അവസാനിക്കുമ്പോള് ഇങ്ങനെ വലത്തേക്ക് മാറുന്നതും നിര്ത്തുക. നാലും ആറും ഉദാഹരണങ്ങള് ശ്രദ്ധിച്ചു വായിച്ച് ഇത് മനസ്സിലായി എന്ന് ഉറപ്പുവരുത്തുക. സംശയമുണ്ടെങ്കില് ചോദിക്കുക.
പ്രവര്ത്തനങ്ങള്
- പ്രവ. 4.
- ഒരു എണ്ണല്സംഖ്യ ഇന്പുട്ട് ആയി എടുത്ത്, ആ സംഖ്യയെക്കാള് ചെറുതും 3, 5 എന്നിവയില് ഒന്നിനെക്കൊണ്ടെങ്കിലും നിശ്ശേഷം ഹരിക്കാവുന്നതുമായ എണ്ണല്സംഖ്യകളുടെ ഒരു ലിസ്റ്റ് ഔട്പുട്ട് ആയി തരുന്ന പ്രോഗ്രാം എഴുതുക. പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനഫലം താഴെക്കാണുന്ന ചിത്രത്തിലെപ്പോലെ ആയിരിക്കണം (കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ ചിത്രത്തില് അമര്ത്തുക).
- പ്രവ. 5.
- ഒരു എണ്ണല്സംഖ്യ ഇന്പുട്ട് ആയി എടുത്ത്, ആ സംഖ്യയെക്കാള് ചെറുതും 3, 5 എന്നിവയില് ഒന്നിനെക്കൊണ്ടെങ്കിലും നിശ്ശേഷം ഹരിക്കാവുന്നതുമായ എണ്ണല്സംഖ്യകളുടെ എണ്ണം ഔട്പുട്ട് ആയി തരുന്ന പ്രോഗ്രാം എഴുതുക. പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനഫലം താഴെക്കാണുന്ന ചിത്രത്തിലെപ്പോലെ ആയിരിക്കണം (കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ ചിത്രത്തില് അമര്ത്തുക). ഇവിടെ ഈ പ്രോഗ്രാം മൂന്നുതവണ പ്രവര്ത്തിപ്പിച്ചിരിക്കുന്നു (IDLE-ല് F5 മൂന്നു തവണ അമര്ത്തിയിരിക്കുന്നു).
- പ്രവ. 6.
- ഒരു എണ്ണല്സംഖ്യ ഇന്പുട്ട് ആയി എടുത്ത്, ആ സംഖ്യയെക്കാള് ചെറുതും 3, 5 എന്നിവയില് ഒന്നിനെക്കൊണ്ടെങ്കിലും നിശ്ശേഷം ഹരിക്കാവുന്നതുമായ എണ്ണല്സംഖ്യകളുടെ തുക ഔട്പുട്ട് ആയി തരുന്ന പ്രോഗ്രാം എഴുതുക. പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനഫലം താഴെക്കാണുന്ന ചിത്രത്തിലെപ്പോലെ ആയിരിക്കണം (കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ ചിത്രത്തില് അമര്ത്തുക). ഇവിടെ ഈ പ്രോഗ്രാം മൂന്നുതവണ പ്രവര്ത്തിപ്പിച്ചിരിക്കുന്നു (IDLE-ല് F5 മൂന്നു തവണ അമര്ത്തിയിരിക്കുന്നു). ഈ മൂന്നു പ്രവര്ത്തനങ്ങള് ചെയ്തുകഴിയുമ്പോഴേക്കും നിങ്ങള് പ്രൊജക്റ്റ് ഓയ്ലറിലെ (Project Euler) ആദ്യത്തെ പ്രശ്നത്തിന്റെ ഉത്തരം കണ്ടെത്തിക്കഴിഞ്ഞു!
അഭാജ്യസംഖ്യകള് - പ്രോഗ്രാം
ഒരു സംഖ്യ അഭാജ്യമാണോ എന്ന് കണ്ടുപിടിക്കാനുള്ള ലളിതമായ പ്രോഗ്രാം എഴുതാന് വേണ്ടത്ര പൈത്തണ് നാം പഠിച്ചുകഴിഞ്ഞു. മുമ്പു പറഞ്ഞതുപോലെ, തന്നിരിക്കുന്ന സംഖ്യ അഭാജ്യമാണോ എന്ന് കണ്ടുപിടിക്കാനുള്ള ഒരു വഴി 1-നെക്കാള് വലുതും ആ സംഖ്യയെക്കാള് ചെറുതുമായ ഏതെങ്കിലും സംഖ്യകൊണ്ട് അതിനെ പൂര്ണ്ണമായി ഹരിക്കാന് പറ്റുമോ എന്നു നോക്കുക എന്നതാണ്. ഇത് ചെയ്യുന്ന ഒരു പ്രോഗ്രാം ഇതാ. ഈ പ്രോഗ്രാമില് ഒരു ചെറിയ സൂത്രപ്പണി ഉപയോഗിച്ചിരിക്കുന്നത് ശ്രദ്ധിക്കുക.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
| # This program checks if a given number is prime or not. To # do this, it checks whether the number is divisible by any # number greater than 1 and less than the input number. # Get the number to check, from the user. number = input ( "Input the number to check : " ) # 1 is a special case. if number = = 1 : print number, "is not prime" else : # We use this boolean variable to remember whether # the input number is divisible by at least one # number in the range 2, 3, ..., number . number_is_prime = True # Check if at least one smaller number properly # divides the given number. If it does, remember # this fact using the boolean variable. for i in range ( 2 , number) : if (number % i) = = 0 : number_is_prime = False # If no smaller number divides the input number, # declare that it is a prime number. Otherwise say # that it is not prime. if number_is_prime = = True : print number, " is prime." else : print number, "is not prime." |
ഈ പ്രോഗ്രാമില് നാം ഇതുവരെ കാണാത്തതായ ഒരേ ഒരു കാര്യമേ ഉള്ളൂ :
number_is_prime
എന്ന പേരുള്ള ബൂളിയന് (ശരി അല്ലെങ്കില് തെറ്റ് എന്നീ രണ്ടു വിലകള് മാത്രമെടുക്കുന്ന) ചരത്തിന്റെ പ്രത്യേക രീതിയിലുള്ള പ്രയോഗം. പ്രവര്ത്തനങ്ങള്
- പ്രവ. 7.
- ഈ പ്രോഗ്രാമില്
number_is_prime
എന്ന ചരത്തിന്റെ ഉപയോഗം എന്താണെന്ന് ആലോചിച്ച് കണ്ടുപിടിക്കുക. എന്തിനാണ് ഇതിന്True
എന്ന വില ആദ്യമേ കൊടുക്കുന്നത്? - പ്രവ. 8.
- രണ്ടു സംഖ്യകള് ഇന്പുട് ആയി എടുത്ത്, ആ രണ്ടു
സംഖ്യകള്ക്കിടയ്ക്കുള്ള എല്ലാ അഭാജ്യ സംഖ്യകളെയും ഔട്പുട്ട് ആയി തരുന്ന
പ്രോഗ്രാം എഴുതുക. പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനഫലം താഴെക്കാണുന്ന
ചിത്രത്തിലെപ്പോലെ ആയിരിക്കണം (കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ
ചിത്രത്തില് അമര്ത്തുക).
സൂചന: ഒരു സംഖ്യ അഭാജ്യമാണോ എന്ന് പരിശോധിക്കുന്ന (ഈ പാഠത്തിലുള്ള) പ്രോഗ്രാമിനെ അനുയോജ്യമായ ഒരു
for
-ന്റെ പരിധിക്കകത്താക്കുക. - പ്രവ. 9.
- ഒരു പൂര്ണ്ണസംഖ്യ ഇന്പുട് ആയി എടുത്ത്, ഒന്നു മുതല് ആ സംഖ്യ വരെയുള്ള ഒറ്റ സംഖ്യകളുടെ തുക ഔട്പുട്ട് ആയി തരുന്ന പ്രോഗ്രാം എഴുതുക.
- പ്രവ. 10.
- രണ്ടു പൂര്ണ്ണസംഖ്യകള് ഇന്പുട് ആയി എടുത്ത്, ആ രണ്ടു സംഖ്യകള്ക്കിടയ്ക്കുള്ള മൂന്നുകൊണ്ട് ഹരിക്കാവുന്ന എന്നാല് അഞ്ചുകൊണ്ട് ഹരിക്കാന് സാധിക്കാത്ത എല്ലാ പൂര്ണ്ണ സംഖ്യകളുടെയും ശരാശരി ഔട്പുട്ട് ആയി തരുന്ന പ്രോഗ്രാം എഴുതുക.
- പ്രവ. 11.
- ഒരു പൂര്ണ്ണസംഖ്യ ഇന്പുട് ആയി എടുത്ത്, ആ സംഖ്യ ഒരു വശമായി വരുന്ന, പൂര്ണ്ണസംഖ്യകള് വശങ്ങളായുള്ള എല്ലാ മട്ടത്രികോണങ്ങളുടെയും മറ്റു രണ്ട് വശങ്ങള് കണ്ടുപിടിക്കുക. പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനഫലം താഴെക്കാണുന്ന ചിത്രത്തിലെപ്പോലെ ആകാം (കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ ചിത്രത്തില് അമര്ത്തുക). ഇവിടെ പ്രോഗ്രാം നാലു പ്രാവശ്യം പ്രവര്ത്തിപ്പിച്ചിട്ടുണ്ട്.
- പ്രവ. 12.
- ഒരു പൂര്ണ്ണസംഖ്യ ഇന്പുട് ആയി എടുത്ത്, ആ സംഖ്യയുടെയത്ര വരികളുള്ള, താഴെക്കൊടുത്തിരിക്കുന്ന ആകൃതിയുള്ള ഒരു ത്രികോണം "*" എന്ന ചിഹ്നം ഉപയോഗിച്ച് വരയ്ക്കുക.(കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ ചിത്രത്തില് അമര്ത്തുക).
- പ്രവ. 13.
- ഒരു പൂര്ണ്ണസംഖ്യ ഇന്പുട് ആയി എടുത്ത്, ആ സംഖ്യയുടെയത്ര വരികളുള്ള, താഴെക്കൊടുത്തിരിക്കുന്ന ആകൃതിയുള്ള ഒരു ത്രികോണം "*" എന്ന ചിഹ്നം ഉപയോഗിച്ച് വരയ്ക്കുക.(കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ ചിത്രത്തില് അമര്ത്തുക).
- പ്രവ. 14.
- ഒരു പൂര്ണ്ണസംഖ്യ ഇന്പുട് ആയി എടുത്ത്, ആ സംഖ്യയുടെയത്ര വരികളുള്ള, താഴെക്കൊടുത്തിരിക്കുന്ന ആകൃതിയുള്ള ഒരു ത്രികോണം "*" എന്ന ചിഹ്നം ഉപയോഗിച്ച് വരയ്ക്കുക.(കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ ചിത്രത്തില് അമര്ത്തുക).
- പ്രവ. 15.
- ഒരു പൂര്ണ്ണസംഖ്യ ഇന്പുട് ആയി എടുത്ത്, ആ സംഖ്യയുടെയത്ര
വരികളുള്ള, താഴെക്കൊടുത്തിരിക്കുന്ന ആകൃതിയുള്ള ഒരു ത്രികോണം "*" എന്ന
ചിഹ്നം ഉപയോഗിച്ച് വരയ്ക്കുക.(കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ
ചിത്രത്തില് അമര്ത്തുക).
പൈത്തണ് : പാഠം ഏഴ്
>> Thursday, April 7, 2011
ആമുഖം
എണ്ണല്സംഖ്യകളുടെ ഘടകങ്ങള് എന്ന ആശയത്തെ കഴിഞ്ഞ പാഠത്തില് പരിചയപ്പെട്ടിരുന്നല്ലോ. രണ്ടേരണ്ട് ഘടകങ്ങള് മാത്രമുള്ള അഭാജ്യസംഖ്യകളെ പൈത്തണ് ഉപയോഗിച്ച് തിരിച്ചറിയുന്നത് എങ്ങനെയെന്നും, ഇവയുടെ ഒരു പട്ടിക എങ്ങനെ ഉണ്ടാക്കാമെന്നതും കഴിഞ്ഞ പാഠത്തില് നാം കണ്ടു. ഈ പാഠത്തില് ഘടകങ്ങളെപ്പറ്റി കൂടുതല് ചില കാര്യങ്ങള് നമുക്ക് കാണാം. ഇതോടൊപ്പം പൈത്തണിലെ ബലവത്തായ ഒരു ഉപാധിയെ പരിചയപ്പെടുകയും ചെയ്യാം.ഘടകങ്ങളും പൊതുഘടകങ്ങളും
കഴിഞ്ഞ പാഠത്തില് ഘടകങ്ങളെ പരിചയപ്പെട്ടത് മറന്നുപോയെങ്കില്: 16-നെ 16 = 1 x 16 = 2 x 8 = 4 x 4 എന്നിങ്ങനെ ഗുണിതങ്ങളായി എഴുതാമല്ലോ. 1, 2, 4, 8, 16 എന്നിവയെ 16-ന്റെ ഘടകങ്ങള് (factors) എന്ന് വിളിക്കുന്നു. ഇതുപോലെ 21-നെ 21 = 1 x 21 = 3 x 7 എന്നിങ്ങനെ എഴുതാം; 1, 3, 7, 21 എന്നിവയാണ് 21-ന്റെ ഘടകങ്ങള്. ഏത് എണ്ണല്സംഖ്യയുടെയും ഘടകമായി 1-ഉം ആ സംഖ്യതന്നെയും ഉണ്ടാവും എന്ന് കുറച്ചൊന്നാലോചിച്ചാല് മനസ്സിലാകും — 1-നെ അതിനോടുതന്നെ പല പ്രാവശ്യം കൂട്ടി ഏത് എണ്ണല്സംഖ്യയിലും എത്തിക്കാം; ഏത് എണ്ണല്സംഖ്യയും "ഒരു പ്രാവശ്യം കൂട്ടിയാല്" ആ സംഖ്യതന്നെയാണുതാനും.
രണ്ട് സംഖ്യകള്ക്ക് പൊതുവായുള്ള ഘടകങ്ങളെ അവയുടെ പൊതുഘടകങ്ങള് (common factors) എന്ന് വിളിക്കുന്നു. ഏതു രണ്ട് എണ്ണല്സംഖ്യകളെടുത്താലും അവയ്ക്ക് പൊതുവായി ഒരു ഘടകമെങ്കിലും ഉണ്ടാവും (എന്തുകൊണ്ട്?). ചില സംഖ്യാജോടികള്ക്ക് ഏറെ പൊതുഘടകങ്ങള് കാണും. മറ്റു ചിലവയ്ക്ക് വളരെ കുറച്ച് പൊതുഘടകങ്ങളേ കാണൂ. ചില ഉദാഹരണങ്ങള് ഇതാ:
ആദ്യത്തെ സംഖ്യ | രണ്ടാമത്തെ സംഖ്യ | ആദ്യത്തെ സംഖ്യയുടെ ഘടകങ്ങള് | രണ്ടാമത്തെ സംഖ്യയുടെ ഘടകങ്ങള് | പൊതു ഘടകങ്ങള് |
---|---|---|---|---|
36 | 16 | 1, 2, 3, 4, 6, 9, 12, 18, 36 | 1, 2, 4, 8, 16 | 1, 2, 4 |
78 | 24 | 1, 2, 3, 6, 13, 26, 39, 78 | 1, 2, 3, 4, 6, 8, 12, 24 | 1, 2, 3, 6 |
120 | 35581 | 1, 2, 3, 4, 5, 6, 8, 10, 12, 15, 20, 24, 30, 40, 60, 120 | 1, 7, 13, 17, 23, 91, 119, 161, 221, 299, 391, 1547, 2093, 2737, 5083, 35581 | 1 |
48 | 210 | 1, 2, 3, 4, 6, 8, 12, 16, 24, 48 | 1, 2, 3, 5, 6, 7, 10, 14, 15, 21, 30, 35, 42, 70, 105, 210 | 1, 2, 3, 6 |
402 | 245 | 1, 2, 3, 6, 67, 134, 201, 402 | 1, 5, 7, 35, 49, 245 | 1 |
ലിസ്റ്റുകളെപ്പറ്റി രണ്ടുകാര്യങ്ങള്
കഴിഞ്ഞ പാഠത്തില്
for, range()
എന്നിവയോടനുബന്ധിച്ച് നാം
ലിസ്റ്റുകളെ പരിചയപ്പെട്ടിരുന്നല്ലോ? അവിടെ സൂചിപ്പിച്ചതുപോലെ പൈത്തണ്
ഉപയോഗിച്ച് പ്രോഗ്രാമുകള് എഴുതുമ്പോള് വളരെയധികം ഉപയോഗപ്പെടുന്ന ഒന്നാണ്
ലിസ്റ്റ്. ലിസ്റ്റുകളെ കൈകാര്യം ചെയ്യുവാനുള്ള ഒട്ടേറെ ഉപാധികള്
പൈത്തണില് ലഭ്യമാണ്. ഇവയില് ലളിതമായ രണ്ട് ഉപാധികളെ ഈ പാഠത്തില് നമുക്ക്
പരിചയപ്പെടാം.ആദ്യമായി നമ്മുടെ കൈയ്യിലുള്ള ഒരു ലിസ്റ്റില് പുതിയ അംഗങ്ങളെ ചേര്ക്കുന്നതെങ്ങനെ എന്ന് നോക്കാം. ഒരു ലിസ്റ്റിലേക്ക് പുതിയ അംഗങ്ങളെ ചേര്ക്കാനുള്ള ഏറ്റവും ലളിതമായ വഴി ആ ലിസ്റ്റിന്റെ
append()
എന്ന ഏകദം ഉപയോഗിക്കുക എന്നതാണ്. കേള്ക്കുന്നയത്ര പ്രയാസമുള്ള കാര്യമല്ല
ഇത്; താഴെക്കാണുന്ന ചെറിയ പ്രോഗ്രാമുകള് പരീക്ഷിച്ചുനോക്കൂ:
1
2
3
4
5
6
7
8
9
10
11
| print "Starting to make a list of the districts in Kerala ..." districts = [ "Thiruvananthapuram" , "Kollam" ] print "Districts added to the list till now : " , districts print "Going to add Kannur to the list ..." districts.append( "Kannur" ) print "Districts added to the list till now : " , districts |
1
2
3
4
5
6
7
8
9
10
11
12
| # This program makes a list of all the odd numbers from 1 to # 100. odd_numbers = [ ] for number in range ( 1 , 101 ): if (number % 2 = = 1 ) : # If the number is odd odd_numbers.append(number) # We are now out of the "for" loop. print "The odd numbers from 1 to 100 are : " , odd_numbers |
ലിസ്റ്റിലേക്ക് ആളെക്കൂട്ടുന്ന വഴി മനസ്സിലായല്ലോ?
myList
എന്ന ലിസ്റ്റിലേക്ക് new_item
എന്ന വസ്തു ചേര്ക്കാനായി myList.append(new_item)
എന്ന് പ്രയോഗിക്കുക. ഇവിടെ new_item
എന്നത് 5, "name"
എന്നിങ്ങനെയുള്ള മൂല്യങ്ങളോ number, name
എന്നിങ്ങനെ ചരങ്ങളോ ആകാം; ചരമാണെങ്കില് അതിന്റെ വിലയാവും ലിസ്റ്റില് കയറിക്കൂടുന്നത്. പ്രവര്ത്തനങ്ങള്
- പ്രവ. 1.
- ഒരു എണ്ണല്സംഖ്യ ഇന്പുട്ട് ആയി എടുത്ത്, ആ സംഖ്യയുടെ ഘടകങ്ങളുടെ ഒരു ലിസ്റ്റ് ഔട്പുട്ട് ആയി തരുന്ന പ്രോഗ്രാം എഴുതുക. പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനഫലം താഴെക്കാണുന്ന ചിത്രത്തിലെപ്പോലെ ആയിരിക്കണം (കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ ചിത്രത്തില് അമര്ത്തുക). ഇവിടെ ഈ പ്രോഗ്രാം മൂന്നു തവണ പ്രവര്ത്തിപ്പിച്ചിരിക്കുന്നു (IDLE-ല് F5 മൂന്നു തവണ അമര്ത്തിയിരിക്കുന്നു).
- പ്രവ. 2.
- രണ്ട് എണ്ണല്സംഖ്യകള് ഇന്പുട്ട് ആയി എടുത്ത്, ഈ സംഖ്യകളുടെ പൊതു ഘടകങ്ങളുടെ ഒരു ലിസ്റ്റ് ഔട്പുട്ട് ആയി തരുന്ന പ്രോഗ്രാം എഴുതുക. പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനഫലം താഴെക്കാണുന്ന ചിത്രത്തിലെപ്പോലെ ആയിരിക്കണം (കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ ചിത്രത്തില് അമര്ത്തുക). ഇവിടെ ഈ പ്രോഗ്രാം മൂന്നു തവണ പ്രവര്ത്തിപ്പിച്ചിരിക്കുന്നു (IDLE-ല് F5 മൂന്നു തവണ അമര്ത്തിയിരിക്കുന്നു).
ഒരു ലിസ്റ്റിന്റെ നീളം (അതില് എത്ര അംഗങ്ങള് ഉണ്ടെന്നുള്ളത്) കാണാനുള്ള വിദ്യയാണ് അടുത്തത്. ഇതിനുള്ള ലളിതമായ വഴി പൈത്തണിലെ
len()
എന്ന ഏകദം ഉപയോഗിക്കുക എന്നതാണ്. ഇത് എങ്ങനെയാണ് ചെയ്യുന്നതെന്ന് താഴെക്കാണുന്ന പ്രോഗ്രാമുകള് പരീക്ഷിച്ചാല് മനസ്സിലാകും.
1
2
3
4
5
6
7
8
| # This is a list of the districts in Kerala. districts = [ "Kasaragod" , "Kannur" , "Wayanad" , "Kozhikode" , \ "Malappuram" , "Palakkad" , "Thrissur" , "Ernakulam" , "Idukki" , \ "Kottayam" , "Alappuzha" , "Pathanamthitta" , "Kollam" , \ "Thiruvananthapuram" ] print "There are " , len (districts), " districts in Kerala." |
1
2
3
4
5
6
7
8
9
10
11
12
13
| # This program finds the number of odd numbers from 1 # to 100. odd_numbers = [ ] for number in range ( 1 , 101 ): if (number % 2 = = 1 ) : # If the number is odd odd_numbers.append(number) # We are now out of the "for" loop. print "There are " , len (odd_numbers), " odd numbers \ from 1 to 100. " |
രണ്ടാമത്തെ പ്രോഗ്രാമില് ഒറ്റസംഖ്യകളുടെ എണ്ണം കാണുക മാത്രം ചെയ്യാന് അവയുടെ ഒരു ലിസ്റ്റ് ഉണ്ടാക്കേണ്ട കാര്യമില്ല എന്നത് ശ്രദ്ധിക്കുക: ഒരു ചരത്തില് ഈ എണ്ണം സൂക്ഷിച്ചാല് മാത്രം മതിയാകും.
len()
എന്ന ഉപാധിയുടെ പ്രയോഗം ഉദാഹരിക്കാന് മാത്രമാണ് ഇവിടെ odd_numbers
എന്ന ലിസ്റ്റ് ഉണ്ടാക്കിയത്. len()
ഉപയോഗിച്ച് ലിസ്റ്റുകളുടെ മാത്രമല്ല, string-കളുടെയും നീളം (string-ല് ഉള്ള സ്പേസും മറ്റു ചിഹ്നങ്ങളും ഉള്പ്പടെയുള്ള
അക്ഷരങ്ങളുടെ എണ്ണം) കാണാം. പ്രയോഗരീതി മുകളിലത്തേതുപോലെ തന്നെ. ഈ സൗകര്യം
ഉപയോഗിച്ച് കേരളത്തിലെ ഏത് ജില്ലയുടെ പേരിനാണ് ഇംഗ്ളീഷില് എഴുതിയാല്
ഏറ്റവും നീളം എന്ന് കണ്ടുപിടിക്കുന്ന ഒരു പ്രോഗ്രാം ഇതാ:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
| # This program finds the "longest" district in Kerala, and # its length when written in English. # This is a list of the districts in Kerala. districts = [ "Kasaragod" , "Kannur" , "Wayanad" , "Kozhikode" , \ "Malappuram" , "Palakkad" , "Thrissur" , "Ernakulam" , \ "Idukki" , "Kottayam" , "Alappuzha" , "Pathanamthitta" ,\ "Kollam" , "Thiruvananthapuram" ] longest_district = "" max_length = 0 for dist in districts : length = len (dist) if length > max_length : # We have found a new district # whose name is longer than all # that we have seen so far. longest_district = dist max_length = length # We are now out of the "for" loop print "The district with the longest name is: " , \ longest_district, "." print "Its name has " , max_length, " letters." |
പ്രവര്ത്തനം
- പ്രവ. 3.
- ഈ ഉദാഹരണങ്ങള് മനസ്സിരുത്തി വായിക്കുക. ഇവ പ്രവര്ത്തിക്കുന്നത് എങ്ങനെയാണെന്ന് മനസ്സിലായി എന്ന് ഉറപ്പുവരുത്തുക. പ്രത്യേകിച്ച് മൂന്നാമത്തെ ഉദാഹരണത്തിന്റെ 13 മുതല് 19 വരെയുള്ള വരികളില് എന്താണ് സംഭവിക്കുന്നതെന്ന് കൃത്യമായി മനസ്സിലാക്കുക.
ഉത്തമ സാധാരണ ഘടകം
രണ്ട് പൂര്ണ്ണസംഖ്യകളുടെ ഏറ്റവും വലിയ പൊതുഘടകത്തെ അവയുടെ ഉത്തമ സാധാരണ ഘടകം (highest common factor, greatest common divisor) എന്ന് വിളിക്കുന്നു: ചുരുക്കത്തില് ഉസാഘ (hcf, gcd) എന്നും. മുകളിലുള്ള പട്ടികയില്നിന്ന് നമുക്ക് കിട്ടുന്ന ഉദാഹരണങ്ങള്:
- ഉസാഘ(16, 36) = 4
- ഉസാഘ(78, 24) = 6
- ഉസാഘ(120, 35581) = 1
- ഉസാഘ(210, 48) = 6
- ഉസാഘ(402, 245) = 1
രണ്ട് പൂര്ണ്ണസംഖ്യകള് ഇന്പുട് ആയി എടുത്ത് അവയുടെ ഉസാഘ കണ്ടുപിടിക്കുന്ന ഒരു പ്രോഗ്രാം നമുക്ക് എങ്ങനെ എഴുതാം? മുകളിലെ രണ്ടു പ്രവര്ത്തനങ്ങളും ചെയ്താല് ഇതിനുള്ള ആശയം കിട്ടും. ലളിതമായ ഒരു രീതി ഇതാ:
- ഇന്പുട്ട് ആയി കിട്ടിയ സംഖ്യകള്
num1, num2
എന്നിവയാണെന്നിരിക്കട്ടെ. -
1
മുതല്num1
വരെയുള്ള ഓരോ സംഖ്യയും ക്രമത്തില്num1, num2
എന്നിവ രണ്ടിനേയും നിശ്ശേഷം ഹരിക്കുന്നുണ്ടോ എന്ന് നോക്കുക. - ഇങ്ങനെ രണ്ടിനേയും ഹരിക്കുന്ന സംഖ്യ കാണുമ്പോള് അത് ഒരു ചരത്തില് (ഇതിനെ നമുക്ക്
gcd
എന്ന് വിളിക്കാം) സൂക്ഷിച്ചുവെക്കുക. -
gcd
-ന്റെ അവസാനമുള്ള വിലയാണ്num1, num2
എന്നിവയുടെ ഉസാഘ.
പ്രവര്ത്തനങ്ങള്
- പ്രവ. 4.
- രണ്ട് സംഖ്യകളുടെ ഉസാഘ കണ്ടുപിടിക്കാന് മുകളില് കൊടുത്ത രീതി ശരിയാകുന്നത് എന്തുകൊണ്ടാണെന്ന് ആലോചിച്ച് മനസ്സിലാക്കുക.
- പ്രവ. 5.
- രണ്ട് എണ്ണല്സംഖ്യകള് ഇന്പുട്ട് ആയി എടുത്ത്, ഈ സംഖ്യകളുടെ ഉസാഘ കണ്ടുപിടിക്കുന്ന പ്രോഗ്രാം മുകളില് കൊടുത്ത രീതിയില് എഴുതുക. പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനഫലം താഴെക്കാണുന്ന ചിത്രത്തിലെപ്പോലെ ആയിരിക്കണം (കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ ചിത്രത്തില് അമര്ത്തുക). ഇവിടെ ഈ പ്രോഗ്രാം നാലു തവണ പ്രവര്ത്തിപ്പിച്ചിരിക്കുന്നു (IDLE-ല് F5 നാലു തവണ അമര്ത്തിയിരിക്കുന്നു).
യൂക്ളിഡിന്റെ അല്ഗോരിതം
ഉസാഘ കണ്ടുപിടിക്കാന് മുകളില് വിവരിച്ച രീതി — രണ്ട് സംഖ്യകളെയും നിശ്ശേഷം ഹരിക്കുന്ന സംഖ്യകള് എല്ലാം കണ്ടുപിടിച്ച് ഇവയില്വച്ച് ഏറ്റവും വലുത് ഉത്തരമായി നല്കുക എന്നത് — തികച്ചും ശരിയായ രീതി തന്നെയാണ്. ഉസാഘയുടെ നിര്വചനത്തിനോട് ഏറെ അടുത്തുനില്ക്കുന്ന രീതിയുമാണിത്. എന്നാല് ഈ രീതിക്ക് ഒരു വലിയ പരിമിതിയുണ്ട്. അതെന്താണെന്നറിയാന് പ്രവ. 4-ല് എഴുതിയ പ്രോഗ്രാമിന് താഴെപ്പറയുന്ന ജോടികള് ഇന്പുട്ട് ആയി കൊടുക്കുക (മുന്നറിയിപ്പ്: കംപ്യൂട്ടറില് തുറന്നിരിക്കുന്ന പ്രമാണങ്ങളൊക്കെ സേവ് ചെയ്തതിനുശേഷം മാത്രം ഇത് പരീക്ഷിക്കുക) :
- 287503, 646609
- 4143937, 6487923
- 55596155, 73187552
ഈ രീതിയുടെ പരിമിതി എന്താണെന്ന് മനസ്സിലായല്ലോ? ഇന്പുട് സംഖ്യകള് വലുതാകുന്തോറും പ്രോഗ്രാം പൂര്ത്തിയാകാനെടുക്കുന്ന സമയവും ആനുപാതികമായി കൂടുന്നു. (സംഖ്യകളുടെ വലുപ്പം കുറച്ച് കൂടുമ്പോഴേക്കും ചിലപ്പോള് കംപ്യൂട്ടര് നിശ്ചലമായി എന്നും വരാം; ഇത് നാം ഉപയോഗിക്കുന്ന
range()
എന്ന ഏകദത്തിന്റെ പ്രവര്ത്തനരീതി കാരണമാണ്. range()
-നു പകരം xrange()
എന്ന് പ്രയോഗിച്ചാല് ഈ പ്രശ്നം ഒഴിവാക്കാം. ഇപ്പോള് കൂടുതല്
വിശദീകരിക്കുന്നില്ല.). ഇതു തന്നെയാണ് ഈ രീതിയുടെ വലിയ പരിമിതിയും.
കുറച്ചൊന്നാലോചിച്ചാല് ഇങ്ങനെ സംഭവിക്കുന്നത് എന്തുകൊണ്ടാണെന്ന് നമുക്ക്
മനസ്സിലാക്കാം. തന്നിരിക്കുന്ന സംഖ്യകളിലൊന്നിന്റെ ഓരോ ഘടകത്തിനെക്കൊണ്ടും
മറ്റേ സംഖ്യയെ ഹരിച്ചുനോക്കുക എന്നതാണല്ലോ ഇവിടെ ചെയ്യുന്നത്? ഇതിനായി
ഒന്നു മുതല് ആദ്യത്തെ സംഖ്യ വരെയുള്ള എല്ലാ സംഖ്യകളെക്കൊണ്ടും ആദ്യത്തെ
സംഖ്യയെ ഹരിച്ചു നോക്കുന്നു. ആദ്യത്തെ സംഖ്യ വലുതാകുന്തോറും പ്രോഗ്രാം
പ്രവര്ത്തിക്കാനെടുക്കുന്ന സമയം ആനുപാതികമായി കൂടുന്നത് ഇതുകൊണ്ടാണ്. ഈ പരിമിതി ഒഴിവാക്കാനാകുന്നതാണോ? ഉസാഘയുടെ നിര്വചനത്തെ അതേപടി പകര്ത്തുകയാണ് ഈ രീതി ചെയ്യുന്നത്: ആദ്യത്തെ സംഖ്യയുടെ ഘടകങ്ങളില്വച്ച് രണ്ടാമത്തെ സംഖ്യയുടെ ഏറ്റവും വലിയ ഘടകത്തെ കണ്ടുപിടിക്കുക എന്നതാണ് ഇവിടെ സംഭവിക്കുന്നത്. ഇതുതന്നെയാണല്ലോ ഉസാഘയുടെ നിര്വചനവും? അങ്ങനെയിരിക്കെ ഇതിലും വേഗത്തില് എങ്ങനെ ഈ പ്രശ്നത്തിന് ഉത്തരം കാണാന് കഴിയും? ഇത് സാധ്യമല്ല എന്ന് ന്യായമായും സംശയിക്കാം.
ഇതിലും മികച്ച — താരതമ്യേന വളരെ കുറച്ച് സമയം മാത്രമെടുക്കുന്ന — രീതികള് നിലവിലുണ്ട് എന്നതാണ് അത്ഭുതകരമായ വസ്തുത. ഇവയില് ഏറ്റവും പ്രശസ്തമായ രീതിക്ക് രണ്ടായിരത്തിമുന്നൂറിലേറെ വര്ഷം പഴക്കമുണ്ട് എന്നതും അത്ഭുതകരം തന്നെ. ബി. സി. 300-നോടടുപ്പിച്ച് എഴുതപ്പെട്ട യുക്ളിഡിന്റെ 'എലമെന്റ്സ്' എന്ന പുസ്തകസഞ്ചയത്തില് രണ്ട് സംഖ്യകളുടെ ഉസാഘ കണ്ടുപിടിക്കാനുള്ള മനോഹരമായ ഒരു രീതി വിവരിച്ചിട്ടുണ്ട്. "യൂക്ളിഡിന്റെ അല്ഗോരിതം" എന്ന പേരില് ഈ രീതി പ്രശസ്തമാണ്. "അല്ഗോരിതം" എന്നതിന് "പ്രശ്നപരിഹാരത്തിനുള്ള വഴി" എന്ന് ഏകദേശം അര്ത്ഥം പറയാം. ഇനി നമുക്ക് യൂക്ളിഡിന്റെ അല്ഗോരിതം എന്താണെന്ന് മനസ്സിലാക്കാന് ശ്രമിക്കാം.
യൂക്ളിഡിന്റെ അല്ഗോരിതത്തിന്റെ അടിസ്ഥാനം ഇതാണ്: a, b എന്നീ പൂര്ണ്ണസംഖ്യകളുടെ ഉസാഘ കണ്ടുപിടിക്കണമെന്ന് കരുതുക.
- a = b ആണെങ്കില് ഉസാഘ (a, b) = a. (എന്തുകൊണ്ട്?) ഇനി a < b ആണെന്ന് കരുതുക (b < a ആണെങ്കില് ഇനിയുള്ള വാദങ്ങളില് aയും bയും തലതിരിച്ചിട്ടാല് മതി.).
- b-യെ a കൊണ്ട് ഹരിച്ചാല് ശിഷ്ടം പൂജ്യമാണെങ്കില് ഉസാഘ (a, b) = a. (എന്തുകൊണ്ട്?)
- b-യെ a കൊണ്ട് ഹരിച്ചാല് ശിഷ്ടം r എന്ന അധിസംഖ്യയാണെന്ന് കരുതുക. ഇങ്ങനെയാണെങ്കില് ഉസാഘ(a, b) = ഉസാഘ(r, a).
ഇവയില് ആദ്യത്തെ രണ്ട് കാര്യങ്ങളും ശരിയാണെന്ന് കാണാന് വലിയ പ്രയാസമില്ല (ആലോചിച്ചുനോക്കൂ). മൂന്നാമത്തെ കാര്യം ശരിയാണോ എന്നത് ഒറ്റനോട്ടത്തില് വ്യക്തമല്ല. ഇത് എന്തുകൊണ്ട് ശരിയാകുന്നു എന്ന് നമുക്കൊന്നു നോക്കാം.
മൂന്നാമത്തെ പിരിവില് b-യെ a കൊണ്ട് ഹരിച്ചാല് ശിഷ്ടം r എന്ന അധിസംഖ്യയാണല്ലോ? അപ്പോള് b = ma + r എന്ന് എഴുതാന് കഴിയുന്ന m എന്ന ഒരു അധിസംഖ്യ നിലവിലുണ്ട് : b-യെ a കൊണ്ട് ഹരിച്ചാല് കിട്ടുന്ന ഉത്തരത്തിന്റെ പൂര്ണ്ണസംഖ്യാഭാഗമാണ് m. ഈ സമവാക്യത്തെ നമുക്ക് r = b - ma എന്നൊന്ന് മാറ്റി എഴുതാം.
a, b എന്നിവ രണ്ടിന്റേയും ഘടകമാണ് f എന്ന് കരുതുക. അപ്പോള് a = pf, b = qf എന്നിങ്ങനെ എഴുതാവുന്ന p,q എന്ന രണ്ട് അധിസംഖ്യകള് ഉണ്ട്. അതുകൊണ്ട് r = b - ma = qf - mpf = f(q - mp). ഇതില്നിന്ന് f എന്നത് r-ന്റെയും ഘടകമാണ് എന്ന് കിട്ടുന്നു. അതുകൊണ്ട് r, a എന്നിവ രണ്ടിന്റേയും ഘടകമാണ് f എന്ന് വരുന്നു.
ഇനി r, a എന്നിവ രണ്ടിന്റേയും ഘടകമാണ് g എന്ന് കരുതുക. അപ്പോള് r = sg, a = tg എന്നിങ്ങനെ എഴുതാവുന്ന s,t എന്ന രണ്ട് അധിസംഖ്യകള് ഉണ്ട്. അതുകൊണ്ട് b = ma + r = mtg + sg = g (mt + s). ഇതില്നിന്ന് g എന്നത് b-യുടെയും ഘടകമാണ് എന്ന് കിട്ടുന്നു. അതുകൊണ്ട് a,b എന്നിവ രണ്ടിന്റേയും ഘടകമാണ് g എന്ന് വരുന്നു.
ഇപ്പറഞ്ഞതില്നിന്ന് നമുക്ക് കിട്ടുന്നത്: a, b എന്നിവയുടെ ഏത് പൊതുഘടകവും r, a എന്നിവയുടെകൂടി പൊതുഘടകമാണ്. മറിച്ച് r, a എന്നിവയുടെ ഏത് പൊതുഘടകവും a, b എന്നിവയുടെ പൊതുഘടകവുമാണ്. അതുകൊണ്ട് a, b എന്നിവയുടെ പൊതുഘടകങ്ങള് തന്നെയാണ് r, a എന്നിവയുടെ പൊതുഘടകങ്ങളും. a, b എന്നിവയുടെ ഏറ്റവും വലിയ പൊതുഘടകവും r, a എന്നിവയുടെ ഏറ്റവും വലിയ പൊതുഘടകവും ഒന്നുതന്നെയാണെന്ന് ഇതില്നിന്ന് വ്യക്തം. അതായത് ഉസാഘ(a,b) = ഉസാഘ(r, a).
അപ്പോള് മുകളിലുള്ള മൂന്നാമത്തെ പിരിവും ശരിയാണ്. യൂക്ളിഡിന്റെ അല്ഗോരിതവും ഇതുതന്നെയാണ്: a, b എന്നീ സംഖ്യകളുടെ ഉസാഘ കാണാന്:
യൂക്ളിഡിന്റെ അല്ഗോരിതം
- a = b ആണെങ്കില് ഉസാഘ(a, b) = a
- a < b എങ്കില്: b-യെ a കൊണ്ട് ഹരിച്ചാല് കിട്ടുന്ന ശിഷ്ടം കണ്ടുപിടിക്കുക. ഇത് r ആണെന്നിരിക്കട്ടെ.
- r = 0 ആണെങ്കില് ഉസാഘ(a, b) = a
- അല്ലെങ്കില് r, a എന്നിവയുടെ ഉസാഘ കണ്ടുപിടിക്കുക; ഇതുതന്നെയാണ് a, b എന്നിവയുടെ ഉസാഘ.
- അതല്ല a > b ആണെങ്കില്: a-യെ b കൊണ്ട് ഹരിച്ചാല് കിട്ടുന്ന ശിഷ്ടം കണ്ടുപിടിക്കുക. ഇത് r ആണെന്നിരിക്കട്ടെ.
- r = 0 ആണെങ്കില് ഉസാഘ(a, b) = b
- അല്ലെങ്കില് r, b എന്നിവയുടെ ഉസാഘ കണ്ടുപിടിക്കുക; ഇതുതന്നെയാണ് a, b എന്നിവയുടെ ഉസാഘ.
- പ്രവ. 5.
- യൂക്ളിഡിന്റെ അല്ഗോരിതം മനസ്സിരുത്തി വായിക്കുക. ഇതിന്റെ പ്രവര്ത്തനരീതി മനസ്സിലായി എന്ന് ഉറപ്പുവരുത്താന്:
- a, b എന്നിവയ്ക്ക് പല വിലകള് കൊടുത്ത് ഈ രീതിയില് (കടലാസും പേനയും ഉപയോഗിച്ച്) അവയുടെ ഉസാഘ കാണുക.
- ഈ പാഠഭാഗത്തിന്റെ ആദ്യം കാണുന്ന മൂന്ന് ജോടി സംഖ്യകളുടെ ഉസാഘയും ഈ രീതി ഉപയോഗിച്ച് കണ്ടുപിടിക്കുക. മൂന്നാമത്തെ ജോടിയുടെ ഉസാഘ കണ്ടുപിടിക്കാന് നിങ്ങളെടുത്ത സമയം കംപ്യൂട്ടര് ഇതു ചെയ്യാന് എടുത്ത സമയവുമായി താരതമ്യം ചെയ്യുക.
- വളരെ വലിയ സംഖ്യകള് (ഉദാ: പത്തക്ക സംഖ്യകള്) ഉള്പ്പെടുന്ന ഒരു ഉദാഹരണമെങ്കിലും യൂക്ളിഡിന്റെ രീതി ഉപയോഗിച്ച് ചെയ്തു നോക്കുക.
- ഈ രീതിയില് ഉസാഘ കണ്ടുപിടിക്കാന് നോക്കിയാല് അത് എപ്പോഴെങ്കിലും അവസാനിക്കുമെന്ന് എന്താണുറപ്പ്? ചില ജോടി സംഖ്യകള്ക്ക് ഇത് അനന്തമായി നീണ്ടുപോയെങ്കിലോ?
- ഈ രീതി ശരിയാണോ? ഏതു ജോടി പൂര്ണ്ണസംഖ്യകളുടെ ഉസാഘയും ഇതുവഴി കിട്ടുമോ?
- നാം ഇതിനുമുമ്പ് കണ്ട ലളിതമായ രീതിയെക്കാള് വളരെ വേഗത്തില് യൂക്ളിഡിന്റെ രീതി ഉത്തരം തരുമോ?
-
while
വരിയുടെ (ലഘുവായ) വ്യാകരണം ഇതാണ്:while condition :
. പേരുസൂചിപ്പിക്കുന്നതുപോലെ ഇവിടെcondition
എന്നത് ഒരു വ്യവസ്ഥ ആണ്. ഉദാഹരണങ്ങളിലെ വ്യവസ്ഥകളെല്ലാം സംഖ്യകളെ അധികരിച്ചാണെങ്കിലും, പൊതുവേ ഇത് എന്തുതരത്തിലുള്ള വ്യവസ്ഥ വേണമെങ്കിലും ആകാം. കൂടുതല് വൈവിധ്യമുള്ള ഉദാഹരണങ്ങള് നമുക്ക് വഴിയേ കാണാം.condition
കഴിഞ്ഞുള്ള:
പ്രത്യേകം ശ്രദ്ധിക്കുക. -
while
വരി കഴിഞ്ഞുവരുന്ന വരികളില്while
-ന്റെ പരിധിയില്പ്പെടുന്ന വരികള് (ഒന്നോ അതിലധികമോ) എഴുതണം. ഇങ്ങനെയുള്ള വരികള് എല്ലാം തന്നെ ഈwhile
വരിയെ അപേക്ഷിച്ച് ഒരു നിശ്ചിത അകലം വലതുവശത്തേക്ക് മാറി ആയിരിക്കണം തുടങ്ങേണ്ടത്. - മുകളിലെ ഉദാഹരണങ്ങളില് നാലു സ്പേസ് വലത്തേക്ക് മാറിയാണ് എഴുതിയിട്ടുള്ളത്. ഇങ്ങനെ നാലു സ്പേസ് വിട്ടെഴുതുന്നതാണ് പൈത്തണ് മാനകം (standard).
- IDLE ഉപയോഗിച്ച് പ്രോഗ്രാം എഴുതുകയാണെങ്കില്
:
എന്നെഴുതി Enter അമര്ത്തുമ്പോള് IDLE തനിയെ തന്നെ എഴുതിത്തുടങ്ങാനുള്ള സൂചകം (cursor) പുതിയ വരിയില് നാലു സ്പേസ് വലത്തേക്ക് മാറ്റിത്തരുന്നത് കാണാം. ഇതൊന്ന് പരീക്ഷിച്ചു നോക്കൂ! ഇങ്ങനെ മാറുന്നില്ലെങ്കില് തൊട്ടുമുമ്പത്തെ വരിയുടെ വ്യാകരണം തെറ്റിയതാവും കാരണം. മിക്കവാറും ഇത് അവസാനം കൊടുക്കേണ്ടതായ:
വിട്ടുപോയതുകൊണ്ടാവും. -
condition
എപ്പോള് വരെ ശരിയായിരിക്കുന്നോ, അത്ര വരെwhile
-ന്റെ പരിധിയില്പ്പെടുന്ന വരികളെല്ലാം പ്രവര്ത്തിപ്പിക്കുക എന്നതാണ്while
-ന്റെ അടിസ്ഥാന സ്വഭാവം. മുകളില് ആദ്യത്തെ ഉദാഹരണം പ്രവര്ത്തിപ്പിച്ചു നോക്കിയാല് ഇത് വ്യക്തമായി മനസ്സിലാകും. ഒരിക്കലും തെറ്റാത്ത ഒരു വ്യവസ്ഥയാണെങ്കില് (ഉദാ: 1 == 1) ഈ വരികളെല്ലാം അനന്തകാലത്തേക്ക് (അല്ലെങ്കില് പ്രോഗ്രാം പുറത്തുനിന്ന് നിര്ത്തുന്നതുവരെ) പ്രവര്ത്തിച്ചുകൊണ്ടേയിരിക്കും. -
while
-ന്റെ പരിധിയില് വരേണ്ടുന്ന — വ്യവസ്ഥ ശരിയായിരിക്കുന്നിടത്തോളം കാലം പ്രവര്ത്തിപ്പിക്കേണ്ടുന്ന — വരികള് എഴുതിക്കഴിഞ്ഞാല് പിന്നീടുള്ള വരിwhile
വരി തുടങ്ങുന്ന അതേ അകലം ഇടതുവശത്തുനിന്ന് വിട്ട് വേണം തുടങ്ങാന്. അതായത്, നാലു സ്പേസ് വലത്തേക്ക് മാറി എഴുതുന്നത് നിര്ത്തണം എന്നര്ത്ഥം.while
-ന്റെ പരിധിയില്പ്പെടുന്ന വരികള് ഏതൊക്കെയാണെന്ന് പൈത്തണ് മനസ്സിലാക്കുന്നത്while
-നു ശേഷവുംwhile
-ന്റെ അതേ നിരപ്പിലുള്ള ആദ്യത്തെ വരി കാണുന്നതിന് മുന്പും നാലു സ്പേസ് വലത്തേക്ക് മാറി വരുന്ന വരികള് ഏതൊക്കെയാണ് എന്ന് നോക്കിയിട്ടാണ്. ഉദാഹരണങ്ങളില്while
-ന്റെ പരിധിക്ക് പുറത്തുള്ള വരികള് എഴുതുന്ന വിലകള് നോക്കിയാല് ഇത് വ്യക്തമാകും. - ഇവിടെ നാലു സ്പേസ് എന്ന് പറഞ്ഞയിടത്തൊക്കെ അതിനു പകരം വേറെ ഏതെങ്കിലും ഒരു നിശ്ചിത അകലം ഇതേ ആവശ്യത്തിന് ഉപയോഗിക്കാം. ഉദാഹരണത്തിന്, ഒരു ടാബ് (കംപ്യൂട്ടറിന്റെ Tab കീ അമര്ത്തിയാല് കിട്ടുന്നത്) ഇതിനായി ഉപയോഗിക്കാം. ഒരേ പ്രോഗ്രാമില് ടാബുകളും സ്പേസുകളും രണ്ടുംകൂടി ഈ ആവശ്യത്തിന് ഉപയോഗിക്കരുത്. ഈ ആവശ്യത്തിന് നാലു സ്പേസ് ഉപയോഗിക്കുന്നതാണ് നല്ല പൈത്തണ് ശൈലിയായി കണക്കാക്കുന്നത്.
- ഇക്കാര്യങ്ങളിലെല്ലാം മുമ്പത്തെ പാഠത്തില് നാം പരിചയപ്പെട്ട
if, for
എന്നിവയുടെ ഘടനയുമായുള്ള സാമ്യം ശ്രദ്ധിക്കുക. -
if, for, while
എന്നിവയുടെ പരിധിക്കുള്ളില് എന്തുവേണമെങ്കിലും എത്രവേണമെങ്കിലും "ആഴത്തില്" എഴുതാം. ഇങ്ങനെ എഴുതുമ്പോള് സ്പേസ് കൊടുക്കുന്ന കാര്യത്തില് ഇതുവരെ പറഞ്ഞ (ലളിതങ്ങളായ) നിയമങ്ങള് പാലിച്ചിരിക്കണമെന്ന് മാത്രം : പുതിയ ഒരു പരിധി തുടങ്ങുമ്പോള് നാലു സ്പേസ് വലത്തേക്ക് മാറി എഴുതിത്തുടങ്ങുക. ഈ പരിധി അവസാനിക്കുമ്പോള് ഇങ്ങനെ വലത്തേക്ക് മാറുന്നതും നിര്ത്തുക. ഇങ്ങനെയുള്ള അനേകം ഉദാഹരണങ്ങള് വഴിയേ കാണാം. - പ്രവ. 6.
-
while
-ല് പറയുന്ന വ്യവസ്ഥ (condition) എപ്പോള് വരെ ശരിയായിരിക്കുന്നോ, അപ്പോള് വരെwhile
-ന്റെ പരിധിയില്പ്പെടുന്ന വരികള് പ്രവര്ത്തിപ്പിക്കുക എന്നതാണല്ലോwhile
-ന്റെ സ്വഭാവം? ഇതുകൊണ്ടുതന്നെwhile
-ന്റെ പരിധിയില്പ്പെടുന്ന വരികള് ഓരോ തവണ പ്രവര്ത്തിപ്പിക്കുമ്പോഴും ഈ വ്യവസ്ഥയെ (നേരിട്ടോ അല്ലാതെയോ)ബാധിക്കുന്ന എന്തെങ്കിലും മാറ്റം വരേണ്ടത് സാധാരണ ഗതിയില് പ്രോഗ്രാം ശരിയാകാന് ആവശ്യമാണ്. മുകളിലെ ഉദാഹരണങ്ങളില് ഇങ്ങനെയുള്ളതരം മാറ്റം വരുത്തുന്ന വരികള് ഏതാണെന്ന് കണ്ടുപിടിക്കുക.
യൂക്ളിഡിന്റെ അല്ഗോരിതം : പൈത്തണില് വീണ്ടും
ഇനി നമുക്ക്while
ഉപയോഗിച്ച് യൂക്ളിഡിന്റെ അല്ഗോരിതത്തിനെ എങ്ങനെ മുഴുമിപ്പിക്കാം എന്ന് നോക്കാം. നമ്മുടെ രണ്ടാമത്തെ പ്രോഗ്രാം ഒന്നുകൂടെ എടുത്തെഴുതുന്നു. പറയാനുള്ള സൗകര്യത്തിനായി a, b-യെക്കാള് വലുതല്ല എന്ന് സങ്കല്പ്പിച്ചിരിക്കുന്നു എന്ന് ഓര്ക്കുക:
12345678910111213141516171819202122232425262728# A first attempt at writing Euclid's Algorithm in Python.
# We assume that a, b are the two input numbers, and that a
# is not larger than b. We want the GCD of a and b to be
# stored in the variable gcd.
if
a
=
=
b :
gcd
=
a
else
:
# Now we know that a is less than b.
r
=
b
%
a
# Find the remainder after division.
if
r
=
=
0
:
gcd
=
a
else
:
# We now write out the code to find the gcd
# of r and a
# First we rename r and a so that we can just
# copy the remaining code from above.
b
=
a
a
=
r
# Now we just copy the code from above.
r
=
b
%
a
# Find the remainder after division.
if
r
=
=
0
:
gcd
=
a
else
:
# Find the gcd of r and a. This is the gcd
# of a and b.
while
ഉപയോഗിച്ച് ഈ കോഡിനെ എങ്ങനെ മുഴുമിപ്പിക്കാം? ഇവിടെr
എന്ന ചരത്തിന്റെ വില പൂജ്യം ആകുന്നതുവരെയാണ് നമുക്ക് ശിഷ്ടം കാണുകയും മറ്റും വേണ്ടത്. ഇത്while
ഉപയോഗിച്ച് എഴുതുമ്പോള് ഇങ്ങനെയാകും:
12345678910111213141516171819202122# A second attempt at writing Euclid's Algorithm in Python,
# using the while loop. We assume that a, b are the two
# input numbers, and that a is not larger than b. We want
# the GCD of a and b to be stored in the variable gcd.
if
a
=
=
b :
gcd
=
a
else
:
# Now we know that a is less than b.
r
=
b
%
a
# Find the remainder after division.
while
not
(r
=
=
0
) :
# First we rename r and a.
b
=
a
a
=
r
# Now we find the remainder for the new values of a
# and b.
r
=
b
%
a
# We are now out of the while loop. This means that
# r == 0, and so the current value of a is the gcd
gcd
=
a
ഇവിടെ ചെയ്തിരിക്കുന്നത് ശ്രദ്ധിക്കുക. ഒമ്പതാമത്തെ വരിയില് b-യെ a കൊണ്ട് ഹരിച്ചാല് കിട്ടുന്ന ശിഷ്ടം r എന്ന ചരത്തില് സൂക്ഷിച്ചുവെക്കുന്നു. r-ന്റെ വില പൂജ്യമാണെങ്കില് നമുക്കുവേണ്ടതായ ഉസാഘ a-യുടെ വില തന്നെയാണെന്ന് നാം കണ്ടു. r-ന്റെ വില പൂജ്യം അല്ലെങ്കില് ഈ വില പൂജ്യം ആകുന്നതുവരെ ഒരുകൂട്ടം കാര്യങ്ങള് ചെയ്യണം. ഇത് സംഭവിക്കുന്നത് 11 മുതല് 18 വരെയുള്ള വരികളിലാണ്. പതിനൊന്നാം വരിയില്while
-ന് തുടക്കമിട്ടിരിക്കുന്നു. ഈwhile
-ന്റെ പരിധി പതിനെട്ടാം വരി വരെയാണ്. പന്ത്രണ്ടുമുതല് പതിനെട്ടുവരെയുള്ള വരികള് എത്രത്തോളം ആവര്ത്തിക്കണം എന്നത് പതിനൊന്നാം വരിയില് പറഞ്ഞിരിക്കുന്നു: "r-ന്റെ വില പൂജ്യം അല്ലാത്തിടത്തോളം".
മുകളിലത്തെ പ്രോഗ്രാമിനെ നമുക്ക് കുറച്ചുകൂടെ ചെറുതാക്കാം.a == b
ആണെങ്കില് b-യെ a കൊണ്ട് ഹരിച്ചാല് ശിഷ്ടം പൂജ്യമാണല്ലോ? ഇക്കാര്യം മുതലെടുത്ത് ആദ്യത്തെ വ്യവസ്ഥ പരിശോധിക്കുന്നത് നമുക്ക് ഒഴിവാക്കാം. ഇനി a, b-യെക്കാള് വലുതാണെങ്കില് b-യെ a കൊണ്ട് ഹരിച്ചാല് ശിഷ്ടം b തന്നെയാണല്ലോ? അതുകൊണ്ട്while
ആദ്യത്തെ തവണ പ്രവര്ത്തിക്കുമ്പോള് a, b എന്നിവയുടെ വിലകള് തമ്മില് വെച്ചുമാറുകയും a,b-യെക്കാള് ചെറുതാകുകയും ചെയ്യും. ഫലം : a, b-യെക്കാള് വലുതായാല് പോലും ഇതേ കോഡ് ശരിയായി പ്രവര്ത്തിക്കും. ഈ മാറ്റങ്ങളൊക്കെ വരുത്തിയ കോഡ് ഇതാ:
123456789101112131415161718# Euclid's Algorithm in Python, version 3. This works for
# all positive numbers a and b. We want the GCD of a and b
# to be stored in the variable gcd.
r
=
b
%
a
# Find the remainder after division.
while
not
(r
=
=
0
) :
# First we rename r and a.
b
=
a
a
=
r
# Now we find the remainder for the new values of a and
# b.
r
=
b
%
a
# We are now out of the while loop. This means that r == 0,
# and so the current value of a is the gcd
gcd
=
a
പ്രവര്ത്തനം
- പ്രവ. 7.
-
- മുകളിലത്തെ പ്രോഗ്രാമും അതിന് തൊട്ടുമുമ്പ് കൊടുത്തിട്ടുള്ള പ്രോഗ്രാമും തമ്മിലുള്ള വ്യത്യാസങ്ങള് എന്തൊക്കെയാണ്? ഈ വ്യത്യാസങ്ങളൊക്കെ ഉണ്ടായിട്ടും രണ്ടു പ്രോഗ്രാമും എന്തുകൊണ്ടാണ് ഒരേപോലെ പ്രവര്ത്തിക്കുന്നത്?
- രണ്ട് എണ്ണല്സംഖ്യകള് ഇന്പുട്ട് ആയി എടുത്ത്, യൂക്ളിഡിന്റെ അല്ഗോരിതം ഉപയോഗിച്ച് ഈ സംഖ്യകളുടെ ഉസാഘ കണ്ടുപിടിക്കുന്ന പ്രോഗ്രാം മുകളില് കൊടുത്ത രീതിയില് എഴുതുക. പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനഫലം താഴെക്കാണുന്ന ചിത്രത്തിലെപ്പോലെ ആയിരിക്കണം (കുറച്ചുകൂടെ വ്യക്തമായ ചിത്രം കാണാന് ഈ ചിത്രത്തില് അമര്ത്തുക). ഇവിടെ ഈ പ്രോഗ്രാം നാലു തവണ പ്രവര്ത്തിപ്പിച്ചിരിക്കുന്നു (IDLE-ല് F5 നാലു തവണ അമര്ത്തിയിരിക്കുന്നു).
- മുകളില് "യൂക്ളിഡിന്റെ അല്ഗോരിതം" എന്ന ഭാഗത്തിന്റെ തുടക്കത്തില് കാണുന്ന മൂന്ന് ജോടി സംഖ്യകള് ഈ പ്രോഗ്രാമിന് ഇന്പുട്ട് ആയി കൊടുക്കുക. ഈ പ്രോഗ്രാം ഇവയുടെ ഉത്തരം കണ്ടുപിടിക്കാന് ഏറെ സമയം എടുക്കുന്നുണ്ടോ?
- വളരെ വലിയ സംഖ്യകള് ഉള്പ്പെടുന്ന ജോടികള് ഈ പ്രോഗ്രാമിന് ഇന്പുട്ട് ആയി കൊടുക്കുക. സംഖ്യകള് വലുതാകുന്ന അതേ തോതില് പ്രോഗ്രാം എടുക്കുന്ന സമയവും കൂടുന്നതായി തോന്നുന്നുണ്ടോ?
പ്രവര്ത്തനം
യൂക്ളിഡിന്റെ അല്ഗോരിതത്തെക്കുറിച്ച് ന്യായമായി ഉണ്ടാകാവുന്ന ചില സംശയങ്ങള്:
ആദ്യത്തെ സംശയത്തിന് പ്രധാന കാരണം ഇതാകാം: ഒരു ജോടി സംഖ്യകളുടെ ഉസാഘ കണ്ടുപിടിക്കാന്വേണ്ടി നാം മറ്റൊരു ജോടി സംഖ്യകളുടെ ഉസാഘ കണ്ടുപിടിക്കേണ്ടി വരുന്നു. ഇത് ഇങ്ങനെ അനന്തമായി നീണ്ടുപോയാലോ? ഇങ്ങനെ നീണ്ടുപോകില്ല എന്ന് കാണാന് ഒരു കാര്യം ശ്രദ്ധിച്ചാല് മതി: രണ്ടാമത്തെ ജോടിയിലെ ഒരു സംഖ്യ (r) ആദ്യത്തെ ജോടിയിലെ രണ്ടു സംഖ്യകളെക്കാളും ചെറുതാണ് (എന്തുകൊണ്ട്?). എല്ലാ സംഖ്യകളും അധിസംഖ്യകളുമാണ്. അധിസംഖ്യകളുടെ കുറഞ്ഞുവരുന്ന ഒരു ശ്രേണി അനന്തമായി നീളുകയില്ലല്ലോ? അതുകൊണ്ടുതന്നെ ഈ രീതിയുടെ പ്രവര്ത്തനവും അനന്തമായി നീളുകയില്ല.
രണ്ടാമത്തെ സംശയത്തിന്റെ ഉത്തരം നാം മുകളില് കണ്ടുകഴിഞ്ഞു: ഏത് ജോടി പൂര്ണ്ണസംഖ്യകളുടെയും ഉസാഘ ഈ രീതിയില് കണ്ടുപിടിക്കാനാകും.
ഈ രീതിയുടെ വേഗത്തെപ്പറ്റി ഒരു ഏകദേശ രൂപം കിട്ടാന് പ്രവര്ത്തനം 5 സഹായിക്കും. ഇതുകൂടാതെ നാം പൈത്തണില് ഈ രീതി എഴുതി പ്രവര്ത്തിപ്പിച്ച് നോക്കുമ്പോഴും ഇത് നമുക്ക് കൂടുതല് ബോധ്യം വരും. യൂക്ളിഡിന്റെ അല്ഗോരിതം ഉസാഘ കണ്ടുപിടിക്കാനായി എത്ര സമയം വരെ എടുക്കാം എന്നതിന് (ഈ സമയം ഇന്പുട്ട് ആയി കിട്ടുന്ന സംഖ്യകളെ ആശ്രയിച്ചിരിക്കുന്നു എന്ന് വ്യക്തമാണല്ലോ?) കൃത്യമായ കണക്കുകളുണ്ട്. ഇവിടെ ഇതിനെപ്പറ്റി കൂടുതല് വിശദീകരിക്കുന്നില്ല; ഈ സമയപരിധി ഫിബോനാച്ചി സംഖ്യകളുമായി നേരിട്ട് ബന്ധപ്പെട്ടിരിക്കുന്നു എന്ന അതിശയകരമായ കാര്യം മാത്രം സൂചിപ്പിക്കുന്നു.
യൂക്ളിഡിന്റെ അല്ഗോരിതം : പൈത്തണില്
ഇനി നമുക്ക് യൂക്ളിഡിന്റെ അല്ഗോരിതം പൈത്തണിലേക്ക് മൊഴിമാറ്റം നടത്താന് ശ്രമിക്കാം. ഇതിന് ഒരു തുടക്കമായി ഈ അല്ഗോരിതത്തിലെ എളുപ്പമുള്ള ഭാഗങ്ങള് പൈത്തണിലേക്ക് പകര്ത്തിനോക്കാം. പറയാനുള്ള സൗകര്യത്തിനായി a, b-യെക്കാള് വലുതല്ല എന്ന് സങ്കല്പ്പിക്കാം:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
| # A first attempt at writing Euclid's Algorithm in Python. # We assume that a, b are the two input numbers, and that a # is not larger than b. We want the GCD of a and b to be # stored in the variable gcd. if a = = b : gcd = a else : # Now we know that a is less than b. r = b % a # Find the remainder after division. if r = = 0 : gcd = a else : # Find the gcd of r and a. This is the gcd of a # and b. |
ഈ പ്രോഗ്രാമില് b -യെ a കൊണ്ട് ഹരിച്ചാല് കിട്ടുന്ന r എന്ന ശിഷ്ടം പൂജ്യമാണെങ്കില് നമുക്ക് വേണ്ട ഉസാഘ കിട്ടുന്നു. r പൂജ്യത്തെക്കാള് വലുതാണെങ്കില് r, a എന്നിവയുടെ ഉസാഘ കണ്ടുപിടിക്കണമല്ലോ? ഇതിനുള്ള കോഡ് നാം എഴുതിയിട്ടില്ല എന്നത് ശ്രദ്ധിക്കുക; ഇതിനുപകരം ഇങ്ങനെ ചെയ്യണം എന്ന് നമ്മെത്തന്നെ ഓര്മ്മിപ്പിക്കാനുള്ള ഒരു കമന്റ് മാത്രം യഥാസ്ഥാനത്ത് എഴുതിയിട്ടുണ്ട്.
ഈ കോഡ് നമുക്ക് എങ്ങനെ എഴുതാം? ഇത് മനസ്സിലാക്കാനായി പ്രവര്ത്തനം 5-ല് ഈ ഭാഗം എങ്ങനെയാണ് ചെയ്തതെന്ന് ആലോചിച്ചു നോക്കുക. തുടക്കത്തില് കൊടുത്ത a, b എന്നിവയ്ക്ക് പകരം r, a എന്നീ വിലകള് പകരം വെച്ച് ആദ്യം മുതല് ചെയ്താല് മതിയാകും: കടലാസും പേനയും ഉപയോഗിച്ച് ചെയ്തപ്പോഴും ഇങ്ങനെയാണല്ലോ ചെയ്തത്? ഇങ്ങനെ രണ്ടാമതും ചെയ്യുമ്പോള് a == b ആവുകയില്ലല്ലോ (എന്തുകൊണ്ട്?) അതുകൊണ്ട് ഇക്കാര്യം പരിശോധിക്കുന്ന വരി ഒഴിവാക്കാം. ഇങ്ങനെ ഒന്നുകൂടി വിസ്തരിച്ചെഴുതിയ പ്രോഗ്രാം ഇതാ:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
| # A first attempt at writing Euclid's Algorithm in Python. # We assume that a, b are the two input numbers, and that a # is not larger than b. We want the GCD of a and b to be # stored in the variable gcd. if a = = b : gcd = a else : # Now we know that a is less than b. r = b % a # Find the remainder after division. if r = = 0 : gcd = a else : # We now write out the code to find the gcd # of r and a # First we rename r and a so that we can just # copy the remaining code from above. b = a a = r # Now we just copy the code from above. r = b % a # Find the remainder after division. if r = = 0 : gcd = a else : # Find the gcd of r and a. This is the gcd # of a and b. |
ഈ പ്രോഗ്രാമില് നാം എന്താണ് ചെയ്തത് എന്ന് ശ്രദ്ധിക്കുക. ആദ്യത്തെ പ്രോഗ്രാമില് "r, a എന്നിവയുടെ ഉസാഘ കണ്ടുപിടിക്കൂ" എന്ന് കമന്റായി എഴുതിയ സ്ഥാനത്ത് നാം ഇക്കാര്യം ചെയ്യാനുള്ള കോഡ് എഴുതി. ഇതിനായി ആദ്യം r, a എന്നിവയെ യഥാക്രമം a, b എന്നിങ്ങനെ പേരുമാറ്റി; ഇങ്ങനെയാകുമ്പോള് a, b എന്നിവയുടെ ഉസാഘ കാണാന് മുകളില് എഴുതിയ കോഡ് അതേപടി പകര്ത്തിയാല് മതിയാകുമല്ലോ. പിന്നെ നാം ഈ കോഡ് മുകളില്നിന്ന് പകര്ത്തിയെഴുതി. ഇവിടെ രണ്ടാമത്തെ തവണ ഹരിക്കുമ്പോള് കിട്ടുന്ന ശിഷ്ടം പൂജ്യമാണെങ്കില് നമുക്കുവേണ്ടതായ ഉസാഘ കിട്ടും; ഇല്ലെങ്കിലാണ് പ്രശ്നം. ഇവിടെയും ശിഷ്ടം കിട്ടുന്ന r പൂജ്യമല്ലെങ്കില് r, a എന്നിവയുടെ ഉസാഘ കണ്ടുപിടിക്കൂ എന്ന് കമന്റായി മാത്രം വീണ്ടും എഴുതിയത് ശ്രദ്ധിക്കുക.
ഈ രീതിയില് പ്രോഗ്രാം വികസിച്ചുവന്നാലുള്ള കുഴപ്പം മനസ്സിലായല്ലോ? സ്ക്രീനിന്റെ വലതുവശത്തേക്ക് പ്രോഗ്രാം അടിവച്ച് നീങ്ങിപ്പോകുന്നതു പോകട്ടെ, എത്രതവണ ശിഷ്ടം കണ്ടാലാണ് ഉസാഘ കിട്ടുക എന്നത് പ്രോഗ്രാം എഴുതുന്ന സമയത്ത് നമുക്കറിഞ്ഞുകൂടാ എന്ന ഒരു വലിയ പ്രശ്നം ഈ രീതിക്കുണ്ട്: ഇന്പുട്ട് കിട്ടുന്ന സംഖ്യകള്ക്കനുസരിച്ച് ഇത് എത്രവേണമെങ്കിലും വരെ ആകാം. ഈ പ്രശ്നം എങ്ങനെ പരിഹരിക്കാം? ഇവിടെ നമ്മുടെ കോഡ് എത്ര വരെ പ്രവര്ത്തിക്കണം എന്നത് ഒരു വ്യവസ്ഥയെ (condition) ആശ്രയിച്ചിരിക്കുന്നു എന്നത് ശ്രദ്ധിക്കുക: ശിഷ്ടമായി കിട്ടുന്ന r എപ്പോള് പൂജ്യമാകുന്നോ അപ്പോള് നമുക്ക് പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനം നിര്ത്താം — ഈ സമയത്തെ a-യുടെ വിലയാണ് നമുക്കുവേണ്ട ഉസാഘ.
വ്യവസ്ഥ ശരിയാകുന്നതുവരെ ആവര്ത്തിക്കാന്: while
ഇങ്ങനെ, ഒരു വ്യവസ്ഥ ശരിയാകുന്നതുവരെ കുറേക്കാര്യങ്ങള് ആവര്ത്തിച്ച് ചെയ്യാന് പൈത്തണിലും മറ്റ് മിക്ക കംപ്യൂട്ടര് ഭാഷകളിലുമുള്ള ഉപാധിയാണ്
while
. ഇതിനുമുമ്പ് നാം പരിചയപ്പെട്ട if, for
എന്നിവയുടെ സമ്മിശ്ര സ്വഭാവമുള്ള ഒരു ഉപാധിയാണ് ഇത്. ഇനി നമുക്ക് while
-നെ പരിചയപ്പെടാം. ഇതിനായി താഴെക്കാണുന്ന പ്രോഗ്രാമുകള് പ്രവര്ത്തിപ്പിച്ചുനോക്കുക.
1
2
3
4
5
6
7
8
| number = 0 while number < 10 : print 'Hello, the number is now ' , number number = number + 1 print 'Now we are out of the while loop.\ The number is now ', number |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
| first = 10 second = 0 count = 1 # How many times will the print statment be executed? while (first > = second) : print "This is round " , count first = first - 1 second = second + 1 count = count + 1 print 'Now we are out of the while loop. first is now ' , \ first, ' and second is now ' , second. |
while-നെപ്പറ്റി വിശദമായി
while
പ്രോഗ്രാമില് ഉപയോഗിക്കുന്ന വിധം നമുക്ക് കുറച്ചുകൂടി വിശദമായി പരിശോധിക്കാം:പ്രവര്ത്തനം
അടിക്കുറിപ്പ്
ഈ പാഠത്തില് നാം കുറെയേറെ പുതിയ കാര്യങ്ങള് കണ്ടു. സാവധാനം മനസ്സിരുത്തി വായിച്ച് ഉദാഹരണങ്ങള് പ്രവര്ത്തിപ്പിച്ചുനോക്കുകയും പ്രവര്ത്തനങ്ങള് ചെയ്തുനോക്കുകയും ചെയ്താല് അധികം പ്രയാസമില്ലാതെ ഈ പാഠത്തിലെ കാര്യങ്ങള് മനസ്സിലാക്കാം. സംശയങ്ങള് ഉണ്ടാകുമ്പോള് കമന്റുകളിലൂടെ ചോദിക്കുക. മുമ്പ് പലതവണ പറഞ്ഞിട്ടുള്ളതുപോലെ, പ്രോഗ്രാമുകള് എഴുതി പ്രവര്ത്തിപ്പിച്ച് തെറ്റുതിരുത്തി പരിശീലിച്ചാല് അനായാസം സ്വായത്തമാക്കാവുന്ന ഒന്നാണ് പ്രോഗ്രാമിംഗ്.പൈത്തണ് : പാഠം എട്ട്
>> Tuesday, November 8, 2011
ആമുഖം
പൈത്തണ് പാഠങ്ങളില് ഇതുവരെ ചരങ്ങള് (variables),
if .. else
, for
, while
എന്നിവയെപ്പറ്റി പഠിച്ചല്ലോ. ഈ പാഠത്തില് നമുക്ക് പൈത്തണിലെ ഏകദങ്ങളെ
(functions) പരിചയപ്പെടാം. "ഏകദം" എന്ന സംസ്കൃത വാക്കിന്റെ അര്ത്ഥം
"ഒന്നിനെ (ഒരു കാര്യത്തെ) തരുന്നത്" എന്നാണ്. പൈത്തണിലെ ഏകദങ്ങളും "ഒരു കാര്യത്തെ
തരുന്ന"വയാണ്. ഇത് എങ്ങനെയാണെന്ന് വഴിയേ മനസ്സിലാകും. പൈത്തണിലെ function
എന്നതിന് "ഏകദം" എന്ന് മൊഴിമാറ്റം ചെയ്യാനുള്ള കാരണം ഇതാണ്. പൈത്തണിലെ
ഏകദങ്ങള് എന്താണെന്നും നമുക്ക് ആവശ്യമുള്ള ഏകദങ്ങളെ സ്വന്തമായി എങ്ങനെ എഴുതാം എന്നും
ഈ പാഠത്തില് മനസ്സിലാക്കാം.
ഏകദങ്ങള് (functions)
പൈത്തണില് സ്വതവേ ലഭ്യമായ (built-in) കുറച്ച് ഏകദങ്ങളെ നാം ഇതുവരെയുള്ള പാഠങ്ങളില് ഉപയോഗിച്ചുകണ്ടു. range
എന്ന ഏകദം ഒരു
എണ്ണല്സംഖ്യയെ സ്വീകരിച്ച് പൂജ്യം മുതല് ആ സംഖ്യയ്ക്ക് മുമ്പുവരെയുള്ള
എണ്ണല്സംഖ്യകളുടെ ഒരു ലിസ്റ്റ് തിരിച്ചുതരുന്നു. $ python Python 2.7.2 (default, Jun 29 2011, 11:10:00) [GCC 4.6.1] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> range(15) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14] >>> quit()
ഇതേ ഏകദത്തിന് മറ്റ് കഴിവുകളുമുണ്ട്:
$python Python 2.7.2 (default, Jun 29 2011, 11:10:00) [GCC 4.6.1] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> range(10) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] >>> range(5, 30) [5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29] >>> range(5, 30, 3) [5, 8, 11, 14, 17, 20, 23, 26, 29] >>> quit()
ഏകദം സ്വീകരിക്കുന്ന വിലകളെ ഏകദത്തിന്റെ "വാക്യങ്ങള്" (arguments) എന്ന് വിളിക്കുന്നു [1]. മുകളില് ആദ്യത്തെ ഉദാഹരണത്തില് 15 എന്ന സംഖ്യയാണ്
range
എന്ന ഏകദത്തിന്റെ വാക്യം. രണ്ടാമത്തെ ഉദാഹരണത്തില് range
-ന്റെ
വാക്യം 10 എന്ന സംഖ്യയാണ്; മൂന്നാമത്തെ ഉദാഹരണത്തില് ഇത് 5, 30 എന്നീ
രണ്ടു സംഖ്യകളും, അവസാനത്തെ ഉദാഹരണത്തില് 5, 30, 3 എന്നീ മൂന്നു
സംഖ്യകളുമാണ്.
ഒരു ലിസ്റ്റ് അല്ലെങ്കില് സ്ട്രിംഗിന്റെ നീളം (അതിലുള്ള അംഗങ്ങളുടെ/ചിഹ്നങ്ങളുടെ എണ്ണം) കാണാന് ഉപയോഗിക്കാവുന്ന
len
ആണ് നാം പരിചയപ്പെട്ട മറ്റൊരു പൈത്തണ് ഏകദം.
$ python Python 2.7.2 (default, Jun 29 2011, 11:10:00) [GCC 4.6.1] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> len([1, 2, 'a', 3, 'b', 'c', 4]) 7 >>> len("Thiruvananthapuram") 18 >>> quit()
ഇവിടെ ആദ്യത്തെ തവണ
len
-ന്റെ വാക്യം [1, 2, 'a', 3, 'b', 'c', 4]
എന്ന ലിസ്റ്റാണ്, രണ്ടാമത്തെ തവണ "Thiruvananthapuram"
എന്ന സ്ട്രിംഗും.
ഒരു ഏകദത്തെ നമ്മുടെ പ്രോഗ്രാമില് പ്രയോഗിക്കാന് (invoke അല്ലെങ്കില് call എന്ന് ഇംഗ്ലീഷില്) ചെയ്യേണ്ടത് ആ ഏകദത്തിന്റെ പേരും, തുടര്ന്ന് '(', ')' എന്നീ ബ്രായ്ക്കറ്റുകള്ക്കിടയിലായി ഏകദത്തിന് കൊടുക്കേണ്ടതായ വാക്യവും എഴുതുക എന്നതാണ്. അതായത്
function_name(argument)
എന്ന്
പ്രോഗ്രാമില് എഴുതുക. മുകളിലെ ഉദാഹരണങ്ങളിലും ഇങ്ങനെയാണല്ലോ ചെയ്തിട്ടുള്ളത്?
പ്രോഗ്രാം പ്രവര്ത്തിക്കുമ്പോള്
function_name(argument)
എന്ന് കാണുന്നയിടത്ത് ഏകദം അതിന്
കൊടുത്തിരിക്കുന്ന വാക്യത്തിനുമേല് പ്രവര്ത്തിച്ചാല് കിട്ടുന്ന മൂല്യം
പകരമായി വരും. ഇത് കുറച്ചുകൂടെ വ്യക്തമാകാന് ഇനിയുള്ള ഉദാഹരണം നോക്കുക:
$ python Python 2.7.2 (default, Jun 29 2011, 11:10:00) [GCC 4.6.1] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> a = 5 >>> a 5 >>> r = range(10) >>> length = len("Thiruvananthapuram") >>> r [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] >>> length 18 >>> range( 14 ) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13] >>> range( len("Pathanamthitta") ) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13] >>> quit()
ഈ ഉദാഹരണത്തില് പ്രത്യേകം ശ്രദ്ധിക്കേണ്ടതായ കാര്യങ്ങള്:
-
range(10)
,len("Thiruvananthapuram")
എന്നീ ഏകദപ്രയോഗങ്ങളുടെ വിലകള് യഥാക്രമംr
,length
എന്നീ ചരങ്ങളില് സൂക്ഷിച്ച് വെച്ചിരിക്കുന്നു. -
range( (len("Pathanamthitta") )
എന്ന പ്രയോഗത്തില്range
എന്ന ഏകദത്തിന് വാക്യമായിlen("Pathanamthitta")
എന്ന ഏകദപ്രയോഗമാണ് കൊടുത്തിരിക്കുന്നത്. പ്രോഗ്രാം പ്രവര്ത്തിക്കുമ്പോള് ആദ്യംlen("Pathanamthitta")
എന്ന പ്രയോഗത്തിന്റെ മൂല്യം --- 14 എന്ന സംഖ്യ --- കണ്ടുപിടിച്ച്len("Pathanamthitta")
എന്ന് പ്രോഗ്രാമില് കാണുന്നതിന് പകരമായി വെയ്ക്കുന്നു. ഇതുകഴിഞ്ഞ്range(14)
എന്ന ഏകദപ്രയോഗത്തിന്റെ മൂല്യം കാണുമ്പോഴാണ്[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13]
എന്ന ലിസ്റ്റ് കിട്ടുന്നത്. - ആദ്യത്തെ ഉദാഹരണങ്ങളില്നിന്ന് ഒരുപക്ഷേ മനസ്സിലായേക്കാവുന്ന ഒരു കാര്യം തെറ്റാണെന്ന് ഇവിടെ കാണാം. ഒരു ഏകദത്തെ പ്രയോഗിക്കുമ്പോള് അതിന്റെ മൂല്യം പ്രിന്റ് ചെയ്യപ്പെടുക എന്നത് ഏകദത്തിന്റെ സ്വഭാവം അല്ല . ഈ ഉദാഹരണത്തിലെ
range(10)
,len("Thiruvananthapuram")
എന്നീ പ്രയോഗങ്ങളുംlen("Pathanamthitta")
എന്ന പ്രയോഗവും ഇത് വ്യക്തമാക്കുന്നു. തന്നിരിക്കുന്ന വ്യഞ്ജകത്തിന്റെ (expression) മൂല്യം പ്രിന്റ് ചെയ്യുക എന്നത് ഷെല്ലിന്റെ പ്രത്യേകത ആയതുകൊണ്ടാണ് ഇതിന് മുമ്പുള്ള ഉദാഹരണങ്ങളില് ഓരോ ഏകദപ്രയോഗത്തിന്റെയും വില പ്രിന്റ് ചെയ്യപ്പെട്ടത്.
ഏകദങ്ങളെ നിര്വചിക്കുന്ന വിധം.
range, len
എന്നിവ കൂടാതെ പൈത്തണില് സ്വതവേ ലഭ്യമായ
(built-in) ഒട്ടനേകം ഏകദങ്ങളുണ്ട്. ഇതുകൂടാതെ ആവശ്യമുള്ള ഏകദങ്ങളെ നമുക്ക് സ്വയം
നിര്വചിച്ച് (define) ഉപയോഗിക്കുകയും ചെയ്യാം. ഇതെങ്ങനെയാണ് ചെയ്യുന്നതെന്ന്
നോക്കാം. ആദ്യമായി, രണ്ട് സംഖ്യകളെ സ്വീകരിച്ച് അവയുടെ തുക തിരിച്ചുതരുന്ന,
ലളിതമായ ഒരു ഏകദം എഴുതാം. ഏകദത്തിന് പേരുകൊടുക്കുമ്പോള് ഏകദം
ചെയ്യുന്നതെന്താണെന്ന് സൂചിപ്പിക്കുന്ന തരത്തിലുള്ള പേര് കൊടുക്കുന്നതാണ് നല്ല രീതി. നമ്മുടെ
ഏകദത്തിന് നമുക്ക് add
എന്ന് പേരുകൊടുക്കാം.
1
2
3
4
5
| # This function takes two numbers as arguments and returns their sum. def add (a, b) : sum = a + b return sum |
add
(a, b)
എന്നതില് a , b
എന്നിവയ്ക്ക് പകരം സംഖ്യകള്
കൊടുത്ത് നമുക്കിത് പരീക്ഷിക്കാം. താഴെക്കാണുന്ന ചിത്രം നോക്കുക (ചിത്രം
വ്യക്തമായി കാണാന് അതില് അമര്ത്തുക).
നാം നിര്വചിച്ച add
എന്ന ഏകദം കൃത്യം രണ്ട് വാക്യങ്ങളേ
സ്വീകരിക്കൂ എന്ന് ചിത്രത്തിലെ അവസാനത്തെ രണ്ട് സന്ദേശങ്ങളില്നിന്ന് മനസ്സിലാക്കാം.
IDLE-നെ കൂടാതെ പൈത്തണ് ഷെല് വഴിയായും (വേണമെങ്കില്) ഈ ഏകദം പ്രയോഗിച്ചുനോക്കാന് കഴിയും. ഇതിനായി ടെര്മിനല് തുറന്ന് add.py എന്ന ഫയല് സേവ് ചെയ്ത ഡയറക്ടറിയിലേക്ക് മാറുക. അവിടെ
python -i add.py
എന്ന കമാന്റ്
കൊടുക്കുക. ഇനി വരുന്ന ഷെല്ലില് നാമെഴുതിയ add
എന്ന ഏകദം
ലഭ്യമാണ് :
$ python -i add.py >>> add (10, 100) 110 >>> add (-2, 5) 3 >>> quit() $ exit
add
എന്ന ഏകദം നാം നിര്വചിച്ചത് എങ്ങനെയാണെന്ന് ഒന്നുകൂടി നോക്കാം:
1
2
3
4
5
| # This function takes two numbers as arguments and returns their sum. def add (a, b) : sum = a + b return sum |
- നിര്വചനത്തിന്റെ ആദ്യത്തെ വരി (നമ്മുടെ പ്രോഗ്രാമിലെ മൂന്നാമത്തെ
വരി) ഏകദത്തിന്റെ ശീര്ഷകമാണ്. ഏകദത്തിന്റെ പേരും അതിന് കൊടുക്കുന്ന
വാക്യങ്ങളുടെ പേരുകളും ഈ വരിയില് വ്യക്തമാക്കുന്നു. ഈ വരിയുടെ വ്യാകരണം
ഇതാണ്:
def function_name ( argument_names ) :
.-
def
എന്നത് ഏകദം നിര്വചിക്കാന് (define) ഉപയോഗിക്കുന്ന പ്രത്യേകവാക്ക് (keyword) ആണ്. define എന്നതിന്റെ ചുരുക്കമാണ് ഇത്. -
def
കഴിഞ്ഞ് അതേ വരിയില് ഏകദത്തിന്റെ (നമുക്ക് ഇഷ്ടമുള്ള) പേര് (function name) കൊടുത്തിരിക്കുന്നു. നമ്മുടെ ഉദാഹരണത്തില് ഇത്add
എന്നാണ്. - ഏകദത്തിന്റെ പേരിനുശേഷം '(', ')' എന്നീ ബ്രായ്ക്കറ്റുകള്ക്കുള്ളിലായി
ഏകദത്തിന്റെ വാക്യങ്ങളുടെ (arguments) പേര്(കള്) പറയുന്നു. ഒന്നിലധികം
വാക്യങ്ങളുണ്ടെങ്കില് അവയെ കോമയുപയോഗിച്ച് വേര്തിരിക്കുന്നു. വാക്യങ്ങളുടെ
പേരും നമുക്ക് ഇഷ്ടമുള്ളത് കൊടുക്കാം. ഇവിടെ
a, b
എന്നിവയാണ് നമ്മുടെ ഏകദത്തിന്റെ വാക്യങ്ങള്. ഈ വരിയുടെ അവസാനമുള്ള:
പ്രത്യേകം ശ്രദ്ധിക്കുക. ഏകദത്തിന്റെ പേരും വാക്യങ്ങളുടെ പേരും പറഞ്ഞുകഴിഞ്ഞു എന്ന് പൈത്തണിന് മനസ്സിലാകുന്നത് ഈ:
കാണുമ്പോഴാണ്.
-
- ഏകദത്തിന്റെ ശീര്ഷകം കഴിഞ്ഞുള്ള വരികളില് ഏകദത്തിന്റെ ഉള്ളടക്കം
എഴുതണം. നമ്മുടെ ഉദാഹരണത്തില് ഏകദത്തിന്റെ ഉള്ളടക്കം
sum = a + b
,return sum
എന്നീ രണ്ടു വരികളാണ്. ഇങ്ങനെയുള്ള വരികള് എല്ലാം തന്നെ ശീര്ഷകത്തെ അപേക്ഷിച്ച് ഒരു നിശ്ചിത അകലം വലതുവശത്തേക്ക് മാറി ആയിരിക്കണം തുടങ്ങേണ്ടത്. കൂടാതെif .. else, while
എന്നിവ ഉള്ളടക്കത്തില് ഉപയോഗിക്കുന്നുണ്ടെങ്കില് നിരപ്പിനെ (indentation) സംബന്ധിച്ച അവയുടെ നിയമങ്ങളും പാലിക്കണം. ഇനിയുള്ള ഉദാഹരണങ്ങള് കാണുമ്പോള് ഇത് മനസ്സിലാകും. - മുകളിലെ ഉദാഹരണത്തില് നാലു സ്പേസ് വലത്തേക്ക് മാറിയാണ് എഴുതിയിട്ടുള്ളത് (നാലാമത്തെ വരി). ഇങ്ങനെ നാലു സ്പേസ് വിട്ടെഴുതുന്നതാണ് പൈത്തണ് മാനകം (standard).
- IDLE ഉപയോഗിച്ച് പ്രോഗ്രാം എഴുതുകയാണെങ്കില് ശീര്ഷകത്തിന്റെ
അവസാനമുള്ള
:
എഴുതി Enter അമര്ത്തുമ്പോള് IDLE തനിയെ തന്നെ എഴുതിത്തുടങ്ങാനുള്ള സൂചകം (cursor) പുതിയ വരിയില് നാലു സ്പേസ് വലത്തേക്ക് മാറ്റിത്തരുന്നത് കാണാം. ഇങ്ങനെ മാറുന്നില്ലെങ്കില് തൊട്ടുമുമ്പത്തെ വരിയുടെ വ്യാകരണം തെറ്റിയതാവും കാരണം. മിക്കപ്പോഴും ഇത് അവസാനം കൊടുക്കേണ്ടതായ:
വിട്ടുപോയതുകൊണ്ടാവും. - ഏകദം തിരിച്ചുതരേണ്ടതായ മൂല്യം നിര്മ്മിക്കാന് ആവശ്യമായ പൈത്തണ് കോഡ്
ഏകദത്തിന്റെ ഉള്ളടക്കത്തില് എഴുതണം. ഇങ്ങനെ എഴുതുമ്പോള് ഏകദത്തിന്റെ വാക്യങ്ങളെ
ചരങ്ങളായി ഉപയോഗിക്കാം. നമ്മുടെ ഉദാഹരണത്തിലെ ഉള്ളടക്കത്തില്
sum
എന്ന ചരത്തിന് ഏകദത്തിന്റെ വാക്യങ്ങളായa, b
എന്നീ ചരങ്ങളുടെ തുക വിലയായി കൊടുത്തിരിക്കുന്നത് ശ്രദ്ധിക്കുക. - ഏകദം തിരിച്ചുതരേണ്ടതായ വില കണ്ടുപിടിച്ചുകഴിഞ്ഞാല് അത്
return
എന്ന പ്രത്യേകവാക്ക് (keyword) ഉപയോഗിച്ച് ഏകദത്തില്നിന്ന് തിരിച്ചുകൊടുക്കാം. നമ്മുടെ ഉദാഹരണത്തില്return sum
എന്ന് എഴുതിയിരിക്കുന്നത് ശ്രദ്ധിക്കുക. - ഇങ്ങനെ
return
എന്ന പ്രയോഗം കണ്ടാല് ആ വില ഏകദത്തില്നിന്ന് തിരിച്ചുകൊടുക്കും. കൂടാതെ പ്രോഗ്രാമിന്റെ പ്രവര്ത്തനം ഏകദത്തിന് പുറത്ത് (പ്രോഗ്രാമില് ഏകദത്തിനെ പ്രയോഗിച്ച സ്ഥലത്ത്) എത്തിച്ചേരുകയും ചെയ്യും. - ഏകദത്തിന്റെ ഉള്ളടക്കം എഴുതിക്കഴിഞ്ഞാല് പിന്നീടുള്ള വരി ഏകദത്തിന്റെ ശീര്ഷകം തുടങ്ങുന്ന അതേ അകലം ഇടതുവശത്തുനിന്ന് വിട്ട് വേണം തുടങ്ങാന്. അതായത്, നാലു സ്പേസ് വലത്തേക്ക് മാറി എഴുതുന്നത് നിര്ത്തണം എന്നര്ത്ഥം. ഏകദത്തിന്റെ നിര്വചനം പൂര്ത്തിയായി എന്ന് പൈത്തണ് മനസ്സിലാക്കുന്നത് ഇത് കാണുമ്പോഴാണ്. ഇനിയുള്ള ഉദാഹരണങ്ങള് കാണുമ്പോള് ഇത് മനസ്സിലാകും.
- ഇവിടെ നാലു സ്പേസ് എന്ന് പറഞ്ഞതിനു പകരം വേറെ ഏതെങ്കിലും ഒരു നിശ്ചിത അകലം ഇതേ ആവശ്യത്തിന് ഉപയോഗിക്കാം. ഉദാഹരണത്തിന്, ഒരു ടാബ് (കംപ്യൂട്ടറിന്റെ Tab കീ അമര്ത്തിയാല് കിട്ടുന്നത്) ഇതിനായി ഉപയോഗിക്കാം. ഒരേ പ്രോഗ്രാമില് ടാബുകളും സ്പേസുകളും രണ്ടുംകൂടി ഈ ആവശ്യത്തിന് ഉപയോഗിക്കരുത്. ഈ ആവശ്യത്തിന് നാലു സ്പേസ് ഉപയോഗിക്കുന്നതാണ് നല്ല പൈത്തണ് ശൈലിയായി കണക്കാക്കുന്നത്.
larger
എന്ന് വിളിക്കാം. തന്നിരിക്കുന്ന രണ്ടു സംഖ്യകളും ഒന്നുതന്നെയാണെങ്കില് ഏകദം ആ സംഖ്യയെത്തന്നെ തിരിച്ചുതരും.
1
2
3
4
5
6
7
8
9
| # This function takes two numbers as arguments and returns the # larger of the two. If both the numbers are the same, the # function returns this number. def larger (first, second) : if first > = second : return first else : return second |
പ്രവര്ത്തനങ്ങള്
- പ്രവ. 1.
- മുകളില് കൊടുത്ത ഏകദം വായിച്ചു മനസ്സിലാക്കുക. ഇത് എങ്ങനെയാണ് പ്രവര്ത്തിക്കുന്നതെന്ന് മനസ്സിലായി എന്ന് ഉറപ്പുവരുത്തുക.
- പ്രവ. 2.
- ഈ പ്രോഗ്രാം larger.py എന്ന ഒരു ഫയലില് സേവ് ചെയ്ത് (larger.py
എന്നതിനു പകരം നിങ്ങള്ക്ക് ഇഷ്ടമുള്ള .py എന്ന് അവസാനിക്കുന്ന
പേരുകൊടുക്കാം) IDLE-ല് (അല്ലെങ്കില് ഷെല്ലില്) ലഭ്യമാക്കുക.
larger
എന്ന ഏകദത്തിന് പല ജോടി സംഖ്യകള് വാക്യങ്ങളായി കൊടുത്ത് അത് ശരിയായി പ്രവര്ത്തിക്കുന്നുണ്ടോ എന്ന് പരിശോധിക്കുക. - പ്രവ. 3.
- രണ്ട് സംഖ്യകള് വാക്യങ്ങളായി സ്വീകരിച്ച് അവയില് ചെറുതിനെ തിരിച്ചുതരുന്ന ഒരു ഏകദം എഴുതുക. ഈ ഏകദത്തിന്
smaller
എന്ന് പേരുകൊടുക്കുക. തന്നിരിക്കുന്ന രണ്ടു സംഖ്യകളും ഒന്നുതന്നെയാണെങ്കില് ഏകദം ആ സംഖ്യയെത്തന്നെ തിരിച്ചുതരണം. ഈ പ്രോഗ്രാം smaller.py എന്ന ഒരു ഫയലില് സേവ് ചെയ്ത് IDLE (അല്ലെങ്കില് ഷെല്) വഴിയായി അതിന്റെ പ്രവര്ത്തനം പരീക്ഷിച്ചുനോക്കുക.
ഇനി നമുക്ക് രണ്ട് സ്ട്രിംഗുകള് വാക്യങ്ങളായി സ്വീകരിച്ച് അവയില് കൂടുതല് നീളമുള്ളതിനെ തിരിച്ചുതരുന്ന ഒരു ഏകദം എഴുതാം. രണ്ട് സ്ട്രിംഗുകള്ക്കും ഒരേ നീളമാണെങ്കില് ഏകദം ആദ്യത്തെ സ്ട്രിംഗിനെ തിരിച്ചുതരും. ഈ ഏകദത്തിന് നമുക്ക്
longer
എന്ന് പേരിടാം. ഈ ഏകദത്തിന് larger
എന്ന ഏകദത്തിനോടുള്ള സാമ്യം ശ്രദ്ധിക്കുക.
1
2
3
4
5
6
7
8
9
| # This function takes two strings as arguments and returns the # longer of the two. If both strings are of the same length, the # function returns the first string. def longer (first, second) : if len (first) > = len (second) : return first else : return second |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
| # This program finds the "longest" district in Kerala, and # its length when written in English. # This is a list of the districts in Kerala. districts = [ "Kasaragod" , "Kannur" , "Wayanad" , "Kozhikode" , \ "Malappuram" , "Palakkad" , "Thrissur" , "Ernakulam" , \ "Idukki" , "Kottayam" , "Alappuzha" , "Pathanamthitta" ,\ "Kollam" , "Thiruvananthapuram" ] longest_district = "" max_length = 0 for dist in districts : length = len (dist) if length > max_length : # We have found a new district # whose name is longer than all # that we have seen so far. longest_district = dist max_length = length # We are now out of the "for" loop print "The district with the longest name is: " , \ longest_district, "." print "Its name has " , max_length, " letters." |
longer
എന്ന ഏകദമുപയോഗിച്ച് എഴുതിയാല് ഇങ്ങനെയാകും:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
| # This program finds the "longest" district in Kerala, and # its length when written in English. # This function takes two strings as arguments and returns the # longer of the two. If both strings are of the same length, the # function returns the first string. def longer (first, second) : if len (first) > = len (second) : return first else : return second # This is a list of the districts in Kerala. districts = [ "Kasaragod" , "Kannur" , "Wayanad" , "Kozhikode" , \ "Malappuram" , "Palakkad" , "Thrissur" , "Ernakulam" , \ "Idukki" , "Kottayam" , "Alappuzha" , "Pathanamthitta" ,\ "Kollam" , "Thiruvananthapuram" ] # At first we don't know which is the longest district, # so we assume it is the first one in the list. longest_district = districts[ 0 ] # Go over each district and compare it with the current # longest district. for district in districts : longest_district = longer(longest_district, district) # We are now out of the "for" loop print "The district with the longest name is: " , \ longest_district, "." print "Its name has " , len (longest_district), " letters." |
longer
എന്ന ഏകദത്തിന്റെ നിര്വചനം ഇങ്ങനെ ഉപയോഗിക്കുന്നതിന് മുമ്പായി (8 മുതല് 12
വരെയുള്ള വരികളിലായി) എഴുതിയിരിക്കുന്നത് ശ്രദ്ധിക്കുക. ഒരു ഏകദം ഉപയോഗിക്കുന്നതിന്
മുമ്പ് അതിന്റെ നിര്വചനം എഴുതിയിരിക്കണം. ഇത് മറ്റൊരു ഫയലില് എഴുതാനുള്ള
സംവിധാനവുമുണ്ട്. അതായത്, ഏകദത്തിന്റെ നിര്വചനം ഒരു ഫയലിലും, അതിന്റെ പ്രയോഗം
വേറൊരു ഫയലിലും വേണമെങ്കില് ആകാം. ഇത് എങ്ങനെയാണ് ചെയ്യേണ്ടതെന്ന് വഴിയേ
കാണാം. ഈ പാഠത്തില് നമുക്ക് ഏകദത്തിന്റെ നിര്വചനവും അത് പ്രയോഗിക്കുന്ന
പ്രോഗ്രാമും ഒരേ ഫയലില്ത്തന്നെ എഴുതാം.
പ്രവര്ത്തനങ്ങള്
- പ്രവ. 4.
- മുകളില് കൊടുത്ത പ്രോഗ്രാം പ്രവര്ത്തിപ്പിച്ചുനോക്കുക.
- പ്രവ. 5.
- ഈ പ്രോഗ്രാം എങ്ങനെയാണ് പ്രവര്ത്തിക്കുന്നതെന്ന് മനസ്സിലാക്കുക. ഇതില്
longer
എന്ന ഏകദം ഉപയോഗിച്ചിരിക്കുന്നത് (27-ആം വരിയില് )എങ്ങനെയാണെന്ന് മനസ്സിലായി എന്ന് ഉറപ്പുവരുത്തുക.
ഇനി സംഖ്യകളുടെ ഒരു ലിസ്റ്റ് സ്വീകരിച്ച് ലിസ്റ്റിലെ ഏറ്റവും വലിയ സംഖ്യ തിരിച്ചുതരുന്ന ഒരു ഏകദം എഴുതാം. ഇതിന്
largest
എന്ന്
പേരിടാം. ഈ ഏകദത്തിന് മുകളിലത്തെ പ്രോഗ്രാമുമായുള്ള സാമ്യം
ശ്രദ്ധിക്കുക. largest
എന്ന ഏകദത്തില്
larger
എന്ന ഏകദം ഉപയോഗിച്ചിരിക്കുന്നത് കാണുക. ഇങ്ങനെ
ഉപയോഗിക്കുവാന്വേണ്ടി, largest
എന്ന ഏകദത്തിന്
മുമ്പായി larger
എന്ന ഏകദത്തിന്റെ നിര്വചനം
എടുത്തെഴുതിയിരിക്കുന്നത് ശ്രദ്ധിക്കുക. ഈ പാഠത്തിലുടനീളം ഇങ്ങനെയാവും നാം
പ്രോഗ്രാമുകളെഴുതുക.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
| # This function takes two numbers as arguments and returns the # larger of the two. If both the numbers are the same, the # function returns this number. def larger (first, second) : if first > = second : return first else : return second # This function takes a list of numbers as arguments and returns # the largest number in the list. def largest (numbers) : # At first we don't know which is the largest number, # so we assume it is the first one in the list. largest = numbers[ 0 ] # Go over each number and compare it with the current # largest. for n in numbers : largest = larger (largest, n) return largest |
largest
എന്ന ഏകദം ലഭ്യമാണ്. സംഖ്യകളുടെ പല ലിസ്റ്റുകള് വാക്യങ്ങളായി കൊടുത്ത്
ഏകദം ശരിയായി പ്രവര്ത്തിക്കുന്നുണ്ട് എന്ന് ഉറപ്പുവരുത്തുക.
ഉദാഹരണങ്ങള്ക്കായി ചിത്രം കാണുക(ചിത്രം
വ്യക്തമായി കാണാന് അതില് അമര്ത്തുക).
പ്രവര്ത്തനം
- പ്രവ. 6.
- സംഖ്യകളുടെ ഒരു ലിസ്റ്റ് വാക്യമായി സ്വീകരിച്ച് ലിസ്റ്റിലെ ഏറ്റവും ചെറിയ സംഖ്യ തിരിച്ചുതരുന്ന ഒരു ഏകദം എഴുതുക. ഇതിന്
smallest
എന്ന് പേരിടുക. ഈ ഏകദം ഒരു ഫയലില് സേവ് ചെയ്ത് ഫയല് IDLE-ലോ ഷെല്ലിലോ പ്രവര്ത്തിപ്പിക്കുക. ഇനി ഈ ഏകദത്തിന് താഴെക്കൊടുത്തിരിക്കുന്ന ലിസ്റ്റുകള് വാക്യങ്ങളായി കൊടുത്തുനോക്കുക. ഉത്തരം ശരിയാകുന്നുണ്ടോ?- [1, 0]
- [1, 1, 1, 1, 0]
- [1, 1, 1, 1, 0, 1]
- [1, 2, 3, 4, 5]
- [5, 4, 3, 2, 1]
ക്രമീകരണം (Sorting)
ഒരു കൂട്ടം സംഖ്യകള് ഇന്പുട്ട് ആയി എടുത്ത് അവയെ അവരോഹണക്രമത്തില് (ഏറ്റവും വലുത് ആദ്യം വരുന്ന ക്രമത്തില് --- ഇംഗ്ളീഷില് descending order) ക്രമപ്പെടുത്തുന്ന ഒരു പ്രോഗ്രാം ഇനി നമുക്ക് എഴുതാം. ഇതിന് നാം എഴുതിയ largest
എന്ന ഏകദം ചെറിയ മാറ്റങ്ങളോടെ ഉപയോഗിക്കാം.
ഇങ്ങനെയോ മറിച്ചുള്ള (ആരോഹണ) ക്രമത്തിലോ സംഖ്യകളെ (മറ്റ് വിവരങ്ങളേയും) അടുക്കുന്നതിന് ക്രമീകരണം (Sorting) എന്നു പറയുന്നു. ഇത് കംപ്യൂട്ടര് പ്രോഗ്രാമുകളില് (അല്ലാതെയും) വളരെയധികം ആവശ്യമുള്ള ഒരു പ്രവര്ത്തനമാണ്. ക്രമീകരിച്ച വിവരങ്ങളില് പരതാനും മറ്റും വളരെ എളുപ്പമാണ്: നൂറുകണക്കിന് പേജുകളിലായി പതിനായിരക്കണക്കിന് വാക്കുകളുടെ അര്ത്ഥങ്ങള് കൊടുത്തിരിക്കുന്ന ഒരു നിഘണ്ടുവില് നമുക്ക് ആവശ്യമുള്ള വാക്കിന്റെ അര്ത്ഥം കണ്ടുപിടിക്കാന് എത്ര എളുപ്പമാണ് എന്നത് ഓര്ക്കുക. അതുപോലെ, ആയിരക്കണക്കിന് ആളുകളുടെ പേരും ഫോണ് നമ്പരും കൊടുത്തിട്ടുള്ള ഫോണ് ഡയറക്ടറിയില് നിന്ന് ഒരാളുടെ ഫോണ് നമ്പര് കണ്ടുപിടിക്കാന് കുറച്ചു സമയമല്ലേ വേണ്ടൂ? നിഘണ്ടുവിലെ വാക്കുകളും ഫോണ് ഡയറക്ടറിയിലെ പേരുകളും (അക്ഷരമാലാ ക്രമത്തില്) ക്രമീകരിച്ചിരിക്കുന്നതുകൊണ്ടാണ് ഇത് സാധ്യമാകുന്നത്. ക്രമീകരണത്തിനായി പലതരം അല്ഗോരിതങ്ങള് (പ്രവര്ത്തനരീതികള്) ലഭ്യമാണ്. ഇവയില് ലളിതമായ ഒരു രീതി നമുക്ക് ഈ പാഠത്തില് പ്രോഗ്രാമായി എഴുതാം. ഈ രീതിയുടെ പേര് "തെരഞ്ഞെടുക്കല് ക്രമീകരണം" (Selection sort) എന്നാണ്. ഇതിന്റെ ആശയം മനസ്സിലാക്കാന് വളരെ എളുപ്പമാണ്. ഈ രീതിയുടെ പ്രവര്ത്തനം ഇങ്ങനെയാണ്:
- ലിസ്റ്റില് അംഗങ്ങളൊന്നുമില്ലെങ്കില്, അഥവാ ലിസ്റ്റില് ഒരേ ഒരു അംഗം (സംഖ്യ) മാത്രമേയുള്ളൂ എങ്കില് ലിസ്റ്റ് ക്രമത്തില്ത്തന്നെയാണ്. ഇങ്ങനെയാണെങ്കില് തന്നിരിക്കുന്ന ലിസ്റ്റിനെത്തന്നെ ഉത്തരമായി തിരിച്ചുകൊടുക്കുക. ഇങ്ങനെ അല്ലെങ്കില് (ലിസ്റ്റില് ഒന്നിലധികം അംഗങ്ങളുണ്ടെങ്കില്):
- ലിസ്റ്റിലെ ഏറ്റവും വലിയ സംഖ്യ ഏതെന്ന് കണ്ടുപിടിക്കുക. ഇത് a എന്ന സംഖ്യ ആണെന്നിരിക്കട്ടെ :
- a എന്ന സംഖ്യ ലിസ്റ്റിന്റെ തുടക്കത്തില് കൊണ്ടുവരിക. ഇതിനായി a-യും ലിസ്റ്റിലെ ആദ്യത്തെ സംഖ്യയും തമ്മില് വച്ചുമാറുക. ഇപ്പോള് ലിസ്റ്റിന്റെ ആദ്യത്തെ സ്ഥാനത്ത് ശരിയായ സംഖ്യയാണ് — അതായത്, ക്രമീകരിച്ച ലിസ്റ്റില് ആദ്യം വരേണ്ടതായ സംഖ്യ തന്നെയാണ് — ഉള്ളത്.
- ഇനി ലിസ്റ്റിന്റെ ആദ്യത്തെ അംഗം ഒഴിച്ചുള്ള ഭാഗം — അതായത്, രണ്ടാമത്തേത് മുതലുള്ള അംഗങ്ങള് ഉള്പ്പെടുന്ന "ഉപലിസ്റ്റ്" — ഇതേ രീതിയില് ക്രമീകരിക്കുക.
- ഇപ്പോള് ലിസ്റ്റിന്റെ തുടക്കത്തില് അതിലെ ഏറ്റവും വലിയ സംഖ്യയാണ്. ലിസ്റ്റിന്റെ രണ്ടാമതു മുതല് അവസാനത്തതു വരെയുള്ള അംഗങ്ങള് ഉള്പ്പെടുന്ന "ഉപലിസ്റ്റ്" ക്രമത്തിലുമാണ്. അതായത്, ലിസ്റ്റ് ക്രമീകരിക്കപ്പെട്ടുകഴിഞ്ഞു.
- ശുഭം!
നമുക്ക് ക്രമീകരിക്കേണ്ട ലിസ്റ്റ് ഇതാണ്:
ഈ ലിസ്റ്റില് ഒന്നിലധികം അംഗങ്ങള് ഉള്ളതുകൊണ്ട് രീതിയുടെ പടി 1 ബാധകമല്ല. അതുകൊണ്ട് നാം പടി 2 പ്രകാരം ലിസ്റ്റിലെ ഏറ്റവും വലിയ സംഖ്യ കണ്ടുപിടിക്കുന്നു. ഇത് 23 ആണ്.
ഇനി പടി (2.i)-ല് പറഞ്ഞിരിക്കുന്നതുപോലെ 23 എന്ന സംഖ്യ ലിസ്റ്റിന്റെ തുടക്കത്തില് കൊണ്ടുവരുന്നു.
ഇപ്പോള് ലിസ്റ്റിന്റെ തുടക്കത്തില് ലിസ്റ്റിലെ ഏറ്റവും വലിയ സംഖ്യയാണ് ഉള്ളത്. അതായത് ലിസ്റ്റിന്റെ തുടക്കം "ക്രമീകരിക്കപ്പെട്ടുകഴിഞ്ഞു". ഇനി ലിസ്റ്റിന്റെ രണ്ടാമത്തേത് മുതലുള്ള ഭാഗം ക്രമീകരിച്ചാല് മതി. ഇത് സൂചിപ്പിക്കാനായി ലിസ്റ്റിലെ ആദ്യത്തെ അംഗത്തിന് — ഇപ്പോള് ക്രമീകരിക്കപ്പെട്ടുകഴിഞ്ഞ ഭാഗത്തിന് — ചാര നിറം കൊടുത്ത് ചിത്രത്തില് കാണിച്ചിരിക്കുന്നു.
ഇനി പടി (2.ii)-ല് പറഞ്ഞിരിക്കുന്നതുപോലെ ലിസ്റ്റിന്റെ ബാക്കിയുള്ള ഭാഗം ഇതേ രീതിയില് ക്രമീകരിക്കണം. ഇതിനായി നാം ഈ പ്രവര്ത്തനരീതി തുടക്കം മുതല്
[15, 1, 7]
എന്ന ലിസ്റ്റിന്റെമേല് പ്രയോഗിക്കണം. ഈ ലിസ്റ്റിലും ഒന്നിലധികം അംഗങ്ങളുള്ളതുകൊണ്ട് രീതിയുടെ ഒന്നാം പടി ഇവിടെ ബാധകമല്ല. അതുകൊണ്ട് നാം പടി 2 പ്രകാരം ഈ ലിസ്റ്റിലെ ഏറ്റവും വലിയ സംഖ്യ കണ്ടുപിടിക്കുന്നു. ഇത് 15 ആണ്.
ഇനി പടി (2.i)-ല് പറഞ്ഞിരിക്കുന്നതുപോലെ 15 എന്ന സംഖ്യ ഈ ലിസ്റ്റിന്റെ തുടക്കത്തില് കൊണ്ടുവരുന്നു. 15 സ്വതവേതന്നെ ഈ ലിസ്റ്റിന്റെ തുടക്കത്തിലായതുകൊണ്ട് അതിന്റെ സ്ഥാനത്തിന് മാറ്റമൊന്നുമില്ല.
ഇനി ഇതേ രീതിയില്
[1, 7]
എന്ന ലിസ്റ്റ് ക്രമീകരിക്കുന്നു.
ഇപ്പോള് ക്രമീകരിക്കാനായി ബാക്കിയുള്ള ലിസ്റ്റില് ഒരേ ഒരംഗം മാത്രമേയുള്ളൂ. ഈ ഏകാംഗ ലിസ്റ്റിനെ നമ്മുടെ രീതിയില് ക്രമീകരിക്കാന് ശ്രമിക്കുമ്പോള് രീതിയുടെ ഒന്നാം പടി ബാധകമാകുന്നു: ഈ ഏകാംഗ ലിസ്റ്റ് സ്വതവേതന്നെ ക്രമീകരിക്കപ്പെട്ടതാണ്. ഇപ്പോള് നമ്മുടെ ലിസ്റ്റ് പൂര്ണ്ണമായും ക്രമീകരിച്ചുകഴിഞ്ഞു.
പ്രവര്ത്തനം
- പ്രവ. 7.
- തെരഞ്ഞെടുക്കല് ക്രമീകരണം എങ്ങനെയാണ് പ്രവര്ത്തിക്കുന്നതെന്ന് മനസ്സിലായെന്ന് ഉറപ്പുവരുത്താന് [35, 2, 3, 56, 5, 7, 9] എന്ന ലിസ്റ്റിന്റെ കടലാസും പേനയുമുപയോഗിച്ച് ഈ രീതിയില് അവരോഹണക്രമത്തില് — ഏറ്റവും വലിയ സംഖ്യ ആദ്യം വരുന്ന ക്രമത്തില് — ക്രമീകരിക്കുക.
തെരഞ്ഞെടുക്കല് ക്രമീകരണം നടപ്പിലാക്കുന്ന ഒരു പൈത്തണ് ഏകദം എഴുതുക എന്നതാണ് ഈ പാഠത്തില് ഇനി നാം ചെയ്യാന് പോകുന്നത്. അതിനുമുമ്പ് ഈ രീതി പ്രവര്ത്തിക്കുന്നത് എങ്ങനെയാണെന്ന് നന്നായി മനസ്സിലാക്കണം. ഈ രീതിയുടെ ഒന്നാമത്തെ പടി ശരിയാണെന്ന് നിസ്സംശയം പറയാമല്ലോ? ഒരേ ഒരംഗം മാത്രമുള്ള ലിസ്റ്റ് തീര്ച്ചയായും ക്രമീകരിക്കപ്പെട്ടതുതന്നെയാണ്.
ഈ രീതിയുടെ കാതലായ ഭാഗം അതിന്റെ രണ്ടാമത്തെ പടിയാണ്. ഇവിടെ ലിസ്റ്റിലെ ഏറ്റവും വലിയ അംഗത്തിനെ കണ്ടുപിടിച്ച് അതിനെ ലിസ്റ്റിന്റെ തുടക്കത്തില് കൊണ്ടുവയ്ക്കുന്നു. ക്രമീകരിക്കപ്പെട്ട ലിസ്റ്റില് ഈ അംഗം ലിസ്റ്റിന്റെ തുടക്കത്തില്ത്തന്നെയാണല്ലോ വരേണ്ടത്? അപ്പോള് ഇങ്ങനെ ചെയ്യുന്നതുവഴി നാം ഉത്തരത്തിലേക്ക് ഒരു ചെറിയ പടി മുന്നേറുന്നു.ഇനി ബാക്കിയുള്ള ലിസ്റ്റ് ക്രമീകരിച്ചാല് മാത്രം മതി. ഇതിന് ഇതേ രീതി ആ ലിസ്റ്റിന്മേല് പ്രയോഗിച്ചാല് മതിയെന്ന് പറയുന്നത് ബോധ്യപ്പെട്ടോ? "ഇതേ രീതി" ആ (ഉപ)ലിസ്റ്റിന്മേല് പ്രയോഗിക്കുമ്പോള് എന്താണ് സംഭവിക്കുന്നതെന്ന് ആലോചിച്ചുനോക്കൂ.
- ഉപലിസ്റ്റില് ഒരംഗമേയുള്ളൂവെങ്കില് ഉപലിസ്റ്റ് ക്രമത്തില്ത്തന്നെയാണ്. ( കൂടാതെ ഈ സംഖ്യ മൊത്തം ലിസ്റ്റിലെ ഏറ്റവും ചെറിയ സംഖ്യയുമാണ് — ഇതെന്തുകൊണ്ടാണെന്ന് ആലോചിച്ചുനോക്കൂ.) അപ്പോള് ലിസ്റ്റ് മുഴുവനായും ക്രമത്തില് ആയിക്കഴിഞ്ഞു.
- ഉപലിസ്റ്റില് ഒന്നിലധികം അംഗങ്ങളുണ്ടെങ്കില് നമ്മുടെ പ്രവര്ത്തനരീതി അതില് ഏറ്റവും വലിയ സംഖ്യയെ കണ്ടുപിടിച്ച് ഉപലിസ്റ്റിന്റെ തുടക്കത്തില് കൊണ്ടുവയ്ക്കുന്നു. ഇത് ശരിയായ നടപടി തന്നെയല്ലേ? ഇനി ഈ ഉപലിസ്റ്റിന്റെ രണ്ടാമത്തെ അംഗം മുതലുള്ള ലിസ്റ്റിനെ ("ഉപൗപ" ലിസ്റ്റിനെ) ക്രമീകരിച്ചാല് മൊത്തം ലിസ്റ്റും ക്രമത്തിലാകും. നമ്മുടെ രീതിയും ഇതുതന്നെയാണ് ചെയ്യുന്നത്.
പ്രവര്ത്തനം
- പ്രവ. 8.
- തെരഞ്ഞെടുക്കല് ക്രമീകരണത്തിന്റെ ആശയം — പ്രത്യേകിച്ച്, "ലിസ്റ്റിന്റെ ബാക്കിയുള്ള ഭാഗത്തിനെ ഇതേ രീതിയില് കൈകാര്യം ചെയ്യുക" എന്നുള്ളത് — ശരിയാണെന്ന് വ്യക്തമായി ബോധ്യപ്പെട്ടാലേ ഈ പാഠത്തിന്റെ ബാക്കിയുള്ള ഭാഗം നന്നായി മനസ്സിലാകൂ. അതുകൊണ്ട് ഈ രീതിയുടെ വിവരണവും വിശദീകരണവും പല പ്രാവശ്യം വായിക്കുക. തന്നിരിക്കുന്ന ഉദാഹരണം പ്രവര്ത്തിക്കുന്നത് ഇതേപോലെയാണെന്ന് ഉറപ്പുവരുത്തുക. പ്രവര്ത്തനം 6 ചെയ്തുനോക്കി അതും മുകളില് പറഞ്ഞതും തമ്മില് പൊരുത്തപ്പെടുന്നുണ്ടോയെന്ന് നോക്കുക.
തെരഞ്ഞെടുക്കല് ക്രമീകരണം, പൈത്തണില് : ഭാഗം 1
തെരഞ്ഞെടുക്കല് ക്രമീകരണത്തിന്റെ ആശയം മനസ്സിലായല്ലോ? ഇനി നമുക്ക് ഈ ആശയം പൈത്തണുപയോഗിച്ച് പ്രാവര്ത്തികമാക്കുന്ന ഒരു പ്രോഗ്രാമെഴുതാം, പല ഘട്ടങ്ങളായി.ഒന്നാമതായി നമുക്ക് ഈ പ്രവര്ത്തനരീതിയുടെ പടി 2.ii-ന് ആവശ്യമുള്ള ഒരു കാര്യം ചെയ്യുന്നത് എങ്ങനെയാണെന്ന് നോക്കാം. രണ്ടോ അതിലധികമോ അംഗങ്ങളുള്ള ഒരു ലിസ്റ്റിന്റെ ആദ്യത്തെ അംഗം ഒഴിച്ചുള്ള ഉപലിസ്റ്റ് എടുക്കുന്നതെങ്ങനെ എന്നതാണ് ഇത്. ഇങ്ങനെയുള്ള ഉപലിസ്റ്റിനെയാണല്ലോ പടി 2.ii പ്രകാരം "ഇതേ രീതിയില്" ക്രമീകരിക്കേണ്ടത്?
ഇങ്ങനെയുള്ള ഒരു ഉപലിസ്റ്റ് എടുക്കല് വളരെ എളുപ്പമുള്ള കാര്യമാണ്:
myList
ഒരു ലിസ്റ്റാണെന്നിരിക്കട്ടെ. ലിസ്റ്റിന്റെ ആദ്യത്തെ
അംഗത്തിന്റെ സ്ഥാനം (index) പൂജ്യം ആണല്ലോ. ലിസ്റ്റിന്റെ രണ്ടാമത്തെ
അംഗത്തിന്റെ സ്ഥാനം 1 ആണ്. ഈ ലിസ്റ്റിന്റെ രണ്ടുമുതലുള്ള അംഗങ്ങള് മാത്രമുള്ള ഒരു
ഉപലിസ്റ്റ് കിട്ടാന് myList[1:]
എന്ന് പറഞ്ഞാല്
മതി. ഇവിടെ 1:
എന്നതിനെ "ഒന്നുമുതല്" എന്ന്
വായിക്കാം. ലിസ്റ്റിലെ സ്ഥാനങ്ങള് പൂജ്യം മുതല്
എണ്ണിത്തുടങ്ങുന്നതുകൊണ്ട്, സ്ഥാനം
ഒന്നുമുതല് എന്ന് പറയുമ്പോള് രണ്ടാമത്തെ അംഗം മുതല് എന്നാണല്ലോ
അര്ത്ഥം. ഈ രീതിയില് ഉപലിസ്റ്റ് എടുക്കുന്ന രീതി വ്യക്തമാക്കുന്ന ചില
ഉദാഹരണങ്ങള് ഇതാ:
$ python Python 2.7.2 (default, Jun 29 2011, 11:10:00) [GCC 4.6.1] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> list1 = [10, 20, 30, 40, 50, 60] >>> list2 = list1[1:] >>> list2 [20, 30, 40, 50, 60] >>> list3 = list2[1:] >>> list3 [30, 40, 50, 60] >>> list4 = list3[1:] >>> list4 [40, 50, 60] >>> quit() $
നമുക്ക് ഒന്നുമുതലല്ലാതെ "പൂജ്യം മുതല്" എണ്ണി പരിചയമില്ലാത്തതുകൊണ്ട് ലിസ്റ്റിന്റെ കാര്യത്തില് ഇങ്ങനെ ചെയ്യേണ്ടിവരുമ്പോള് കുറച്ച് അപരിചിതത്വം തോന്നും. ഇത് അല്പകാലത്തെ പരിചയം കൊണ്ട് മാറിക്കൊള്ളും.
തെരഞ്ഞെടുക്കല് ക്രമീകരണം, പൈത്തണില് : ഭാഗം 2
ലിസ്റ്റിലെ വലിയ സംഖ്യ കണ്ടുപിടിച്ചുകഴിഞ്ഞാല് (പടി 2) അത് ലിസ്റ്റിന്റെ തുടക്കത്തില് കൊണ്ടുവരണമല്ലോ. ഇതിനായി വലിയ സംഖ്യയും ലിസ്റ്റിന്റെ തുടക്കത്തിലെ സംഖ്യയും തമ്മില് വച്ചുമാറണം (പടി 2.i). ഇത് ചെയ്യാനായി വലിയ സംഖ്യ ലിസ്റ്റില് എവിടെയാണ് എന്നറിയണം. സംഖ്യകളുടെ ഒരു ലിസ്റ്റ് സ്വീകരിച്ച് അതില് ഏറ്റവും വലുത് കണ്ടുപിടിച്ചുതരുന്ന ഒരു ഏകദം ( largest
) നാം എഴുതിയല്ലോ. ഈ ഏകദം
പക്ഷേ വലിയ സംഖ്യ ലിസ്റ്റില് എവിടെയായിരുന്നു എന്ന് പറഞ്ഞുതരുന്നില്ല. ഇനി ഈ ഏകദത്തില്
ചെറിയ മാറ്റം വരുത്തി, ഏറ്റവും വലിയ സംഖ്യ ലിസ്റ്റില് എവിടെയാണ് എന്നതുകൂടി
തിരിച്ചുതരുന്ന ഒരു ഏകദം നമുക്കെഴുതാം. ഈ ഏകദത്തിനെ നമുക്ക്
largest2
എന്ന് വിളിക്കാം.
largest
എന്ന ഏകദത്തിനുള്ളില് larger
എന്ന
ഏകദം ഉപയോഗിച്ചല്ലോ? രണ്ട് സംഖ്യകള് സ്വീകരിച്ച് അവയില് വലുതിനെ തിരിച്ചുതരിക
എന്നതാണ് ഈ ഏകദം ചെയ്യുന്നത്. largest2
എന്ന ഏകദത്തില്
പ്രയോഗിക്കാനായി larger
-ല് ചെറിയൊരു മാറ്റം
വേണം. മുമ്പത്തേതുപോലെ, ഈ ഏകദം രണ്ട് സംഖ്യകളെ വാക്യങ്ങളായി സ്വീകരിച്ച്
അവയില് വലുത് ഏതാണെന്ന് പറയണം. ഇതു കൂടാതെ ഒരു കാര്യം കൂടി നമുക്ക് അറിയണം :
ഏകദത്തിന് വാക്യങ്ങളായി കൊടുത്ത രണ്ട് സംഖ്യകളില് രണ്ടാമത്തേതാണോ വലിയത് എന്ന
കാര്യമാണ് അറിയേണ്ടത്. (ഇതറിയുന്നത് എന്തിനാണെന്ന് വഴിയേ മനസ്സിലാകും.) ഈ
മാറ്റങ്ങളോടുകൂടിയ larger
-നെ നമുക്ക്
larger2
എന്ന് വിളിക്കാം. larger2
നമുക്ക്
തിരിച്ചുതരുന്നത് രണ്ടംഗങ്ങളുള്ള ഒരു ലിസ്റ്റാണ്. ഈ ലിസ്റ്റില് ആദ്യത്തെ അംഗം ഈ ഏകദത്തിന്റെ
വാക്യങ്ങളിലെ വലിയ സംഖ്യയാണ്. രണ്ടാമത്തെ അംഗം ഒരു ബൂളിയന് മൂല്യം (ശരി
അല്ലെങ്കില് തെറ്റ്) ആണ്. രണ്ടു വാക്യങ്ങളില് രണ്ടാമത്തേതാണ് വലുതെങ്കില്
ഈ മൂല്യം True
ആണ്. അല്ലെങ്കില്
False
-ഉം. larger2
നമുക്ക് ഇങ്ങനെയെഴുതാം:
1
2
3
4
5
6
7
8
9
10
| # This function takes two numbers as arguments and returns a list # with two values. The first member of the list is the larger of # the two arguments. The second member is True if the second # argument is larger than the first, and False otherwise. def larger2(first, second) : if first > = second : return [first, False ] else : return [second, True ] |
$ python -i larger2.py >>> larger2(1, 10) [10, True] >>> larger2(10, 1) [10, False] >>> quit()
പ്രവര്ത്തനം
- പ്രവ. 9.
- പലപല സംഖ്യാജോടികള് വാക്യങ്ങളായി കൊടുത്ത്
larger2
എന്ന ഏകദം പ്രവര്ത്തിപ്പിക്കുക. ഏകദത്തിന്റെ പ്രവര്ത്തനം മനസ്സിലായി എന്ന് ഉറപ്പുവരുത്തുക.
ഇനി നമുക്ക് ഈ ഏകദമുപയോഗിച്ച് നമുക്കുവേണ്ട
largest2
എന്ന ഏകദം എഴുതാം:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
| # This function takes two numbers as arguments and returns a list # with two values. The first member of the list is the larger of # the two arguments. The second member is True if the second # argument is larger than the first, and False otherwise. def larger2(first, second) : if first > = second : return [first, False ] else : return [second, True ] # This function takes a list of numbers as arguments and finds # the largest number in the list. It returns a list of two numbers: # the largest number in the list, and the index of the largest number. def largest2(numbers) : # At first we don't know which is the largest number, # so we assume it is the first one in the list. largest = numbers[ 0 ] index = 0 # Go over each number and compare it with the current # largest. i = 0 for n in numbers : [largest, flipped] = larger2(largest, n) if flipped : index = i i = i + 1 return [largest, index] |
മുകളിലെ പ്രോഗ്രാം നമുക്കൊന്ന് വിശദമായി വായിക്കാം. ഒന്നു മുതല് പത്തുവരെയുള്ള വരികളില്
larger2
എന്ന ഏകദത്തിന്റെ നിര്വചനമാണ്. 12 മുതല്
31 വരെയുള്ള വരികളിലാണ് largest2
എന്ന ഏകദം
നിര്വചിച്ചിരിക്കുന്നത്. ഇതില്ത്തന്നെ 12 മുതല് 14 വരെയുള്ള വരികള് ഏകദം എന്താണ്
ചെയ്യുന്നത് (ചെയ്യേണ്ടത്!) എന്ന് വിശദമാക്കുന്ന കമന്റാണ്. ഇങ്ങനെ കമന്റ് എഴുതുന്നതിന്റെ
ഒരു പ്രധാന ഉദ്ദേശം ഇതാണ് : മറ്റൊരാള്ക്കോ (കുറച്ചുകാലം കഴിഞ്ഞാല്
നമുക്കുതന്നെയോ) ഏകദത്തിന്റെ ഉള്ളടക്കം വായിക്കാതെതന്നെ അത് എന്താണ് ചെയ്യുന്നതെന്ന്
മനസ്സിലാക്കാന് സാധിക്കണം. ഇങ്ങനെ കമന്റ് എഴുതുന്നത് സമയനഷ്ടവും തെറ്റിദ്ധാരണകളും
ഒഴിവാക്കാന് സഹായിക്കുന്നു.
പതിനാറാം വരിയില് ഏകദത്തിന്റെ ശീര്ഷകമാണ്. ഏകദത്തിന്റെ പേര്
largest2
എന്നാണെന്നും, അത് numbers
എന്ന് പേരുള്ള ഒരു
വാക്യത്തെ സ്വീകരിക്കുന്നുവെന്നും ഇവിടെ പറഞ്ഞിരിക്കുന്നു.
largest, index
എന്നിങ്ങനെ രണ്ട് അംഗങ്ങളുള്ള ഒരു ലിസ്റ്റിനെയാണ്
ഈ ഏകദം തിരിച്ചുകൊടുക്കുന്നതെന്ന് 31-ആം വരിയില് കാണാം. ഏകദത്തിന്റെ കമന്റ്
പ്രകാരം ഇതില് ആദ്യത്തെ അംഗം ( largest
) ഏകദത്തിന്റെ
വാക്യമായ numbers
എന്ന ലിസ്റ്റിലെ ഏറ്റവും വലിയ
സംഖ്യയാണ്; index
ആകട്ടെ, ഈ വലിയ സംഖ്യ
numbers
-ല് എവിടെ വരുന്നു എന്ന് പറയുന്നു.
ഈ രണ്ടു കാര്യങ്ങള് കണ്ടുപിടിക്കാന് ഏകദം ചെയ്യുന്നത്
numbers
എന്ന ലിസ്റ്റിന്റെ തുടക്കം മുതല് അവസാനം വരെ ക്രമത്തില് നോക്കുക എന്നതാണ് (വരികള്
25 – 29). ഓരോ സമയത്തും അതുവരെ കണ്ട ഏറ്റവും വലിയ സംഖ്യയെ
largest
എന്ന ചരത്തില് സൂക്ഷിച്ചുവെയ്ക്കുന്നു; അതിന്റെ സ്ഥാനത്തിനെ
index
എന്ന ചരത്തിലും. ലിസ്റ്റിലെ ആദ്യത്തെ സംഖ്യ കാണുന്ന സമയത്ത് ആ സംഖ്യ
തന്നെയാണ് അതുവരെ കണ്ടതില്വച്ച് ഏറ്റവും വലുത്. അതുകൊണ്ട് തുടക്കത്തില്ത്തന്നെ
largest
എന്നതിന്റെ വില numbers
എന്ന ലിസ്റ്റിലെ
ആദ്യസംഖ്യയായും ( numbers[0]
) index
എന്നത് അതിന്റെ സ്ഥാനമായും (പൂജ്യം) നിജപ്പെടുത്തുന്നു (വരികള് 19, 20). പൈത്തണില്
ലിസ്റ്റിലെ സ്ഥാനങ്ങള് എണ്ണിത്തുടങ്ങുന്നത് 0, 1, 2, ... എന്നിങ്ങനെയാണെന്നത് ഓര്ക്കുക.
ഇനി നമുക്ക് ഏകദത്തിന്റെ പ്രധാനപ്പെട്ട ഭാഗമായ
for
-ന്റെ കാര്യം
നോക്കാം (വരികള് 25 — 29). ലിസ്റ്റിലെ ഓരോ അംഗത്തേയും ക്രമമായി
എടുത്തുനോക്കുക എന്നതാണ് ഈ for
ചെയ്യുന്നത്. വിശദമായി പറഞ്ഞാല്,
ആദ്യത്തെ തവണ ഈ for
-ന്റെ ഉള്ളടക്കം (26 മുതല് 29 വരെയുള്ള
വരികള് ) പ്രവര്ത്തിക്കുമ്പോള് n
എന്ന ചരത്തിന്റെ
വില numbers
എന്ന ലിസ്റ്റിലെ ആദ്യത്തെ (സ്ഥാനം പൂജ്യം
ആയിട്ടുള്ള, അതായത് numbers[0]
) അംഗത്തിന്റെ വിലയാണ്. രണ്ടാമത്തെ
തവണ ഇത് രണ്ടാമത്തെ അംഗത്തിന്റെ (സ്ഥാനം 1, numbers[1]
)
വിലയാണ്. ഇങ്ങനെ തുടര്ന്നുപോകുന്നു.
ഇങ്ങനെ പോകുമ്പോള് ഇതുവരെ കണ്ട ഏറ്റവും വലിയ സംഖ്യയെക്കാള് (ഇതിനെ
largest
എന്ന ചരത്തില് സൂക്ഷിച്ചുവെച്ചിട്ടുണ്ട് എന്നോര്ക്കുക) വലിയ ഒരു
സംഖ്യ കണ്ടാല് രണ്ടു കാര്യങ്ങളാണ് ചെയ്യേണ്ടത്:
- പുതുതായി കണ്ട വലിയ സംഖ്യയെ
largest
എന്ന ചരത്തില് സൂക്ഷിച്ചുവെയ്ക്കുക. - ഈ വലിയ സംഖ്യയുടെ സ്ഥാനം
index
എന്ന ചരത്തില് സൂക്ഷിച്ചുവെയ്ക്കുക.
i
എന്ന ചരത്തില് ഈ സ്ഥാനം
സൂക്ഷിക്കുന്നു. തുടക്കത്തില് i
-യുടെ വില പൂജ്യമാണ് (വരി
24). for
-ന്റെ ഉള്ളടക്കം ഓരോ തവണ പ്രവര്ത്തിക്കുമ്പോഴും
( numbers
-ലെ ഓരോ പുതിയ അംഗത്തെ കാണുമ്പോഴും)
i
-യുടെ വില ഒന്നുവീതം കൂട്ടുന്നു (വരി 29).
for
-ന്റെ ഉള്ളടക്കത്തിലെ ആദ്യത്തെ വരിയില് (വരി 26) നാം മുമ്പ്
നിര്വചിച്ച larger2
എന്ന ഏകദം പ്രയോഗിക്കുന്നു. ഈ ഏകദത്തിന്
ഇതുവരെ കണ്ട ഏറ്റവും വലിയ സംഖ്യയും ( largest
) ലിസ്റ്റില്
പുതുതായി കണ്ട സംഖ്യയുമാണ് ( n
) വാക്യങ്ങളായി കൊടുക്കുന്നത്. ഏകദം
തിരികെത്തരുന്ന രണ്ടംഗ ലിസ്റ്റിനെ [largest, flipped]
എന്ന
ലിസ്റ്റിലേക്ക് സൂക്ഷിച്ചുവെയ്ക്കുന്നത് ശ്രദ്ധിക്കുക. ഇങ്ങനെ ചെയ്യുമ്പോള് ഏകദത്തിന്റെ
മറുപടിയിലെ ആദ്യ അംഗത്തിന്റെ വില — { largest
-ന്റെ
മുമ്പുണ്ടായിരുന്ന വില, n
-ന്റെ വില} എന്നിവയില് വലിയ സംഖ്യ
— largest
എന്ന ചരത്തില് വരുന്നു. കൂടാതെ ഏകദത്തിന്റെ
മറുപടിയിലെ രണ്ടാമത്തെ അംഗത്തിന്റെ വില — { largest
-ന്റെ
മുമ്പുണ്ടായിരുന്ന വില, n
-ന്റെ വില} എന്നിവയില് രണ്ടാമത്തേതാണ്
വലിയതെങ്കില് True
, അല്ലെങ്കില് False
— flipped
എന്ന (ബൂളിയന്) ചരത്തില് വരുന്നു.
27-ആമത്തെ വരിയില്
flipped
എന്ന ബൂളിയന് ചരത്തിന്റെ
വില True
ആണോ എന്ന് പരിശോധിക്കുന്നു. ആണെങ്കില്
അതിനര്ത്ഥം numbers
എന്ന ലിസ്റ്റിലെ ഇപ്പോള് നാം പരിഗണിക്കുന്ന
സംഖ്യ (അതായത് n
-ന്റെ വില ) ലിസ്റ്റില് ഇതിന് മുമ്പുവരെയുള്ള എല്ലാ
സംഖ്യകളെക്കാളും വലുതാണ് എന്നാണ് (എന്തുകൊണ്ട്?). അപ്പോള് ഈ സംഖ്യ
largest
എന്ന ചരത്തിലും, അതിന്റെ ലിസ്റ്റിലുള്ള സ്ഥാനം
index
എന്ന ചരത്തിലും സൂക്ഷിച്ചുവെയ്ക്കണം. ഇതില് ആദ്യത്തെ കാര്യം 26-ആം
വരിയില് ചെയ്തുകഴിഞ്ഞു. 27-ആം വരിയില് ഇപ്പോള് പരിഗണിക്കുന്ന സംഖ്യയുടെ
ലിസ്റ്റിലുള്ള സ്ഥാനം (ഇത് i
എന്ന ചരത്തിലുണ്ടല്ലോ?)
index
-ലേക്ക് സൂക്ഷിച്ചുവെയ്ക്കുന്നു.
31-ആമത്തെ വരിയില്
largest, index
എന്നീ ചരങ്ങളുടെ വിലകള്
ഒരു ലിസ്റ്റിലാക്കി ഏകദത്തില്നിന്ന് തിരിച്ചുകൊടുക്കുന്നു. ഇത് for
-ന്റെ
പരിധിക്ക് പുറത്താണ് എന്നത് ശ്രദ്ധിക്കുക. അതുകൊണ്ട് numbers
എന്ന
ലിസ്റ്റിലെ എല്ലാ അംഗങ്ങളേയും പരിഗണിച്ച് അവയില് ഏറ്റവും വലുതിന്റെ വില
largest
എന്ന ചരത്തിലും അതിന്റെ ലിസ്റ്റിലുള്ള സ്ഥാനം
index
എന്ന ചരത്തിലും സൂക്ഷിച്ചുവെച്ചതിന് ശേഷമാണ് ഈ തിരിച്ചുകൊടുക്കല്.
ഈ പാഠ്യപദ്ധതിയില് ഇതുവരെ കണ്ടതില്വച്ച് ഏറ്റവും സങ്കീര്ണ്ണമായ ലോജിക്കാണ്
largest2
എന്ന ഏകദത്തിലേത്. അതുകൊണ്ട്:
- പ്രോഗ്രാം IDLE-ലോ ഷെല്ലിലോ പലതവണ (പല സംഖ്യാ ലിസ്റ്റുകളെ വാക്യങ്ങളായി കൊടുത്ത്) പ്രവര്ത്തിപ്പിച്ചുനോക്കുക. പറഞ്ഞതുപോലെയൊക്കെ സംഭവിക്കുന്നുണ്ടോ?
- പ്രോഗ്രാം എങ്ങനെയാണ് ഇക്കാര്യങ്ങളൊക്കെ ചെയ്യുന്നതെന്ന് ആലോചിക്കുക. ഒരുപക്ഷേ ഇതിന്റെ പ്രവര്ത്തനം അതിശയകരമാണെന്ന് തോന്നിയേക്കാം. ഇതില് അതിശയകരമായി അത്രയ്ക്കൊന്നുമില്ല. ഈ പ്രോഗ്രാമും അതിന്റെ വിശദീകരണവും കുറച്ചുപ്രാവശ്യം ശ്രദ്ധിച്ച് വായിക്കുക. മനസ്സിലാകാത്ത കാര്യങ്ങള് ചോദിക്കുക. ഇതേരീതിയിലുള്ള പല ഉദാഹരണങ്ങള് കാണുമ്പോള് ഈ രീതിയില് ചിന്തിക്കാന് നിങ്ങളും പഠിക്കും.
- കുറെയേറെ വര്ഷത്തെ പ്രോഗ്രാമിംഗ് സംബന്ധമായ പരിചയം (പ്രോഗ്രാമുകള് എഴുതിയും വായിച്ചും, പ്രോഗ്രാമിംഗിനെപ്പറ്റിയുള്ള ലേഖനങ്ങളും മറ്റും വായിച്ചുമുള്ളത്) അടിസ്ഥാനപ്പെടുത്തിയാണ് ഈ പ്രോഗ്രാം എഴുതിയത്. അതുകൊണ്ട് ഇതേപോലെയൊരു പ്രോഗ്രാം എങ്ങനെ എഴുതും എന്നാലോചിച്ച് നിങ്ങള് വിഷമിക്കരുത്. നിങ്ങള് സ്വയം ഇതേ കാര്യത്തിനുള്ള പ്രോഗ്രാമെഴുതിയാല് മറ്റൊരു രീതിയിലായിരിക്കും അത് വരിക. പ്രോഗ്രാമിന്റെ ലോജിക് ശരിയായിരിക്കുന്നിടത്തോളം ഇതൊരു പ്രശ്നമല്ല തന്നെ. അതുപോലെ തന്നെ, എന്നെക്കാള് പ്രോഗ്രാമിംഗ് വൈദഗ്ധ്യമുള്ള/വ്യത്യസ്തമായ രീതിയില് പ്രോഗ്രാമിംഗ് പരിശീലിച്ച ഒരാള് എഴുതുന്ന പ്രോഗ്രാം മറ്റൊരു രീതിയിലായിരിക്കും. ഇക്കാര്യത്തില് പ്രോഗ്രാമിംഗ് ഭാഷ, മനുഷ്യഭാഷ പോലെതന്നെയാണ്. നമ്മുടേതിനെക്കാള് വളരെ ലളിതമായ ഭാഷയാണല്ലോ നാലു വയസുള്ള ഒരു കുട്ടിയുടേത്. എന്നാല്പ്പോലും തനിക്ക് ആവശ്യമുള്ള കാര്യങ്ങളൊക്കെ പ്രകടിപ്പിക്കാന് നാലു വയസുള്ള കുട്ടിക്കും കഴിയുന്നുമുണ്ടല്ലോ. അതുപോലെ തന്നെയാണ് പ്രോഗ്രാമിംഗിലും. നമുക്കറിയാവുന്ന ഭാഷ ഉപയോഗിച്ച് പ്രോഗ്രാമുകള് എഴുതി ശീലിക്കുക. നല്ലതെന്ന് തോന്നുന്ന ശൈലികള് കാണുമ്പോള് മനസ്സിലാക്കി വയ്ക്കുക. പരിചയം കൂടുന്തോറും ഭാഷയും മാറിക്കൊണ്ടിരിക്കും.
പ്രവര്ത്തനം
- പ്രവ. 10.
- സംഖ്യകളുടെ ഒരു ലിസ്റ്റ് വാക്യമായി സ്വീകരിച്ച്, ലിസ്റ്റിലെ ഏറ്റവും
ചെറിയ സംഖ്യയും അതിന്റെ ലിസ്റ്റിലെ സ്ഥാനവും തിരിച്ചുതരുന്ന ഒരു ഏകദം
എഴുതുക. ഏകദത്തിന്
smallest2
എന്ന് പേരിടുക.largest2
എന്ന ഏകദം ചെയ്തതുപോലെ, ഈ രണ്ട് സംഖ്യകളെ ഒരു ലിസ്റ്റായി വേണംsmallest2
തിരിച്ചുതരേണ്ടത്. പല പല ലിസ്റ്റുകള് വാക്യമായി കൊടുത്ത് ഈ ഏകദം ശരിയായി പ്രവര്ത്തിക്കുന്നുണ്ടെന്ന് ഉറപ്പുവരുത്തുക.
തെരഞ്ഞെടുക്കല് ക്രമീകരണം, പൈത്തണില് : ഭാഗം 3
തെരഞ്ഞെടുക്കല് ക്രമീകരണത്തിന്റെ പ്രവര്ത്തനരീതി ഒന്നുകൂടെ എടുത്തെഴുതാം :- ലിസ്റ്റില് അംഗങ്ങളൊന്നുമില്ലെങ്കില്, അഥവാ ലിസ്റ്റില് ഒരേ ഒരു അംഗം (സംഖ്യ) മാത്രമേയുള്ളൂ എങ്കില് ലിസ്റ്റ് ക്രമത്തില്ത്തന്നെയാണ്. ഇങ്ങനെയാണെങ്കില് തന്നിരിക്കുന്ന ലിസ്റ്റിനെത്തന്നെ ഉത്തരമായി തിരിച്ചുകൊടുക്കുക. ഇങ്ങനെ അല്ലെങ്കില് (ലിസ്റ്റില് ഒന്നിലധികം അംഗങ്ങളുണ്ടെങ്കില്):
- ലിസ്റ്റിലെ ഏറ്റവും വലിയ സംഖ്യ ഏതെന്ന് കണ്ടുപിടിക്കുക. ഇത് a എന്ന സംഖ്യ ആണെന്നിരിക്കട്ടെ :
- a എന്ന സംഖ്യ ലിസ്റ്റിന്റെ തുടക്കത്തില് കൊണ്ടുവരിക. ഇതിനായി a-യും ലിസ്റ്റിലെ ആദ്യത്തെ സംഖ്യയും തമ്മില് വച്ചുമാറുക. ഇപ്പോള് ലിസ്റ്റിന്റെ ആദ്യത്തെ സ്ഥാനത്ത് ശരിയായ സംഖ്യയാണ് — അതായത്, ക്രമീകരിച്ച ലിസ്റ്റില് ആദ്യം വരേണ്ടതായ സംഖ്യ തന്നെയാണ് — ഉള്ളത്.
- ഇനി ലിസ്റ്റിന്റെ ആദ്യത്തെ അംഗം ഒഴിച്ചുള്ള ഭാഗം — അതായത്, രണ്ടാമത്തേത് മുതലുള്ള അംഗങ്ങള് ഉള്പ്പെടുന്ന "ഉപലിസ്റ്റ്" — ഇതേ രീതിയില് ക്രമീകരിക്കുക.
- ഇപ്പോള് ലിസ്റ്റിന്റെ തുടക്കത്തില് അതിലെ ഏറ്റവും വലിയ സംഖ്യയാണ്. ലിസ്റ്റിന്റെ രണ്ടാമതു മുതല് അവസാനത്തതു വരെയുള്ള അംഗങ്ങള് ഉള്പ്പെടുന്ന "ഉപലിസ്റ്റ്" ക്രമത്തിലുമാണ്. അതായത്, ലിസ്റ്റ് ക്രമീകരിക്കപ്പെട്ടുകഴിഞ്ഞു.
- ശുഭം!
larger2, largest2
എന്നീ ഏകദങ്ങള് നാം നേരത്തെ കണ്ടവ തന്നെയാണ്. ഇവയുപയോഗിച്ച് എഴുതിയ selection_sort
എന്ന ഏകദമാണ് ക്രമീകരണം നടപ്പിലാക്കുന്നത്.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
| # This function takes two numbers as arguments and returns a list # with two values. The first member of the list is the larger of # the two arguments. The second member is True if the second # argument is larger than the first, and False otherwise. def larger2(first, second) : if first > = second : return [first, False ] else : return [second, True ] # This function takes a list of numbers as arguments and finds # the largest number in the list. It returns a list of two numbers: # the largest number in the list, and the index of the largest number. def largest2(numbers) : # At first we don't know which is the largest number, # so we assume it is the first one in the list. largest = numbers[ 0 ] i = 0 index = 0 # Go over each number and compare it with the current # largest. for n in numbers : [largest, flipped] = larger2(largest, n) if flipped : index = i i = i + 1 return [largest, index] # The following function performs Selection Sort on its argument, # which is a list of numbers. It returns the sorted list. def selection_sort(numberlist) : # Step 1 : If numberlist contains at most one element, then it # is already sorted. So return the list without any change. if len (numberlist) < = 1 : return numberlist # If we reach this point, then numberlist contains more than # one element. # Step 2 : Find the largest element in numberlist, and its # position in the list. [a, index_of_a] = largest2(numberlist) # Step 2.i : Exchange the positions of the number 'a' and the # first number in the list. numberlist[index_of_a] = numberlist[ 0 ] numberlist[ 0 ] = a # Step 2.ii : Sort the sublist numberlist[1:] "in the same # way". numberlist[ 1 :] = selection_sort(numberlist[ 1 :]) # The list is now sorted! Return it. return numberlist |
ഈ പ്രോഗ്രാമിലെ ആദ്യത്തെ രണ്ട് ഏകദങ്ങള് (
larger2,
largest2
എന്നിവ ) നാം മുമ്പുകണ്ടവ തന്നെയാണ്.
selection_sort
എന്നു പേരായ പുതിയ ഏകദം 33 മുതല് 65 വരെയുള്ള
വരികളിലാണ്. ഇതില് ആദ്യത്തെ രണ്ട് വരികളില് ഈ ഏകദം എന്താണ് ചെയ്യുന്നതെന്ന്
സൂചിപ്പിക്കുന്ന കമന്റാണ്.
selection_sort
എന്ന ഏകദം സംഖ്യകളുടെ ഒരു ലിസ്റ്റിനെ
വാക്യമായി സ്വീകരിക്കുന്നു. വാക്യത്തിന്റെ പേര് numberlist
എന്നാണ്. ഈ ഏകദത്തിന്റെ ഉള്ളടക്കത്തില് തെരഞ്ഞെടുക്കല് ക്രമീകരണത്തിന്റെ
പ്രവര്ത്തനരീതിയെ അതേപടിയെന്നോണം പകര്ത്തിയിരിക്കുന്നു.
ഏകദത്തില് ആദ്യം ചെയ്യുന്നത്
numberlist
എന്ന ലിസ്റ്റില് ഒന്നോ
അതില് കുറവോ അംഗങ്ങളേ ഉള്ളോ എന്ന് നോക്കുക എന്നതാണ് (വരി
41). ഇങ്ങനെയാണെങ്കില് ഇതേ ലിസ്റ്റിന്റെ മാറ്റങ്ങളൊന്നുമില്ലാതെ തിരിച്ചുകൊടുത്ത്,
ഏകദത്തിന്റെ പ്രവര്ത്തനം അവസാനിപ്പിക്കുന്നു (വരി 42).
ഇങ്ങനെ അല്ലെങ്കില് — ലിസ്റ്റില് രണ്ടോ അതില് കൂടുതലോ അംഗങ്ങളുണ്ടെങ്കില് — 42-ആം വരി പ്രവര്ത്തിക്കുകയില്ല. ഇതിനു പകരം ലിസ്റ്റിലെ ഏറ്റവും വലിയ സംഖ്യയും ഈ സംഖ്യയുടെ ലിസ്റ്റിലെ സ്ഥാനവും
largest2
എന്ന
ഏകദമുപയോഗിച്ച് കണ്ടുപിടിച്ച്, a, index_of_a
എന്നീ
ചരങ്ങളിലായി സൂക്ഷിക്കുന്നു (വരി 50). ഇതുകഴിഞ്ഞ് a
-യെ —
ലിസ്റ്റിലെ ഏറ്റവും വലിയ സംഖ്യയെ — ലിസ്റ്റിന്റെ തുടക്കത്തില്
കൊണ്ടുവരുന്നു. ഇതിനായി ലിസ്റ്റിന്റെ തുടക്കത്തിലുള്ള സംഖ്യയെ a
ഇരുന്നയിടത്തും, a
-യെ ലിസ്റ്റിന്റെ തുടക്കത്തിലും കൊണ്ടുവയ്ക്കുന്നു
(വരികള് 55, 56).
ഇനി ആകെ ചെയ്യാനുള്ളത് ലിസ്റ്റിന്റെ ആദ്യത്തെ അംഗം ഒഴിച്ചുള്ള ഭാഗം — അതായത്, രണ്ടാമത്തേത് മുതലുള്ള അംഗങ്ങള് ഉള്പ്പെടുന്ന "ഉപലിസ്റ്റ്" — ഇതേ രീതിയില് ക്രമീകരിക്കുക എന്നതാണ്. ഇതിനായി ചെയ്യുന്നത് (വരി 61):
-
numberlist[1:]
എന്ന ഈ ഉപലിസ്റ്റിനെselection_sort
എന്ന (ഇതേ!) ഏകദത്തിന് വാക്യമായി കൊടുക്കുക. ഏകദം ഈ ഉപലിസ്റ്റിനെ ക്രമീകരിച്ച് തിരിച്ചുതരും. - ഇങ്ങനെ ക്രമീകരിച്ച് കിട്ടിയ ഉപലിസ്റ്റിനെ അത് ഇരിക്കേണ്ട സ്ഥാനത്ത്
—
numberlist
എന്ന ലിസ്റ്റിന്റെ രണ്ടാമത്തെ അംഗം മുതലുള്ള ഉപലിസ്റ്റായി — വയ്ക്കുക.
selection_sort
എന്ന ഏകദം ശരിയായി പ്രവര്ത്തിക്കുന്നുണ്ടോ
എന്ന് പരിശോധിക്കാന് ഈ പ്രോഗ്രാം ഒരു ഫയലില് സേവ് ചെയ്ത് IDLE-ലോ ഷെല്ലിലോ
പ്രവര്ത്തിപ്പിച്ചുനോക്കാം. ഷെല്ലില് പ്രവര്ത്തിപ്പിച്ചതിന്റെ ഉദാഹരണം ഇതാ
(selectionsort.py എന്ന ഫയലിലാണ് സേവ് ചെയ്തത്).
അവരോഹണക്രമത്തിലാണ് (വലിയ സംഖ്യകള് ആദ്യം വരുന്ന ക്രമത്തില്) നമ്മുടെ
പ്രോഗ്രാം ലിസ്റ്റിനെ ക്രമീകരിക്കുന്നതെന്ന് ഓര്ക്കുക : $ python -i selectionsort.py >>> selection_sort ([1]) [1] >>> selection_sort ([1, 2, 3, 4, 5]) [5, 4, 3, 2, 1] >>> selection_sort ([12, 45, 23, 54, 78, 3, 100]) [100, 78, 54, 45, 23, 12, 3] >>> selection_sort ([2, 1]) [2, 1] >>> selection_sort ([1, 2]) [2, 1] >>> quit() $
പ്രവര്ത്തനം
- പ്രവ. 11.
- സംഖ്യകളുടെ ഒരു ലിസ്റ്റ് വാക്യമായി സ്വീകരിച്ച്, ലിസ്റ്റിനെ
ആരോഹണക്രമത്തില് (ഏറ്റവും ചെറിയ സംഖ്യ ആദ്യം വരുന്ന ക്രമത്തില്)
തെരഞ്ഞെടുക്കല് ക്രമീകരണം ഉപയോഗിച്ച് ക്രമപ്പെടുത്തുന്ന ഒരു ഏകദം
എഴുതുക. ഇതിന്
selection_sort2
എന്ന് പേരുകൊടുക്കുക. മുമ്പെഴുതിയsmallest2
എന്ന ഏകദം ഇതിനായി ഉപയോഗിക്കുക. പല പല ലിസ്റ്റുകള് വാക്യമായി കൊടുത്ത് ഈ ഏകദം ശരിയായി പ്രവര്ത്തിക്കുന്നുണ്ടെന്ന് ഉറപ്പുവരുത്തുക.
ഉപസംഹാരം
for, while
എന്നിവ ഉപയോഗിച്ച് പ്രവര്ത്തനങ്ങള് ആവര്ത്തിച്ച്
ചെയ്യുന്നതിന് iteration (ആവര്ത്തനം എന്നര്ത്ഥം) എന്നാണ് പറയുന്നത്.
നാമെഴുതിയ selection_sort
എന്ന ഏകദത്തില് അതേ
ഏകദത്തിനെത്തന്നെ പ്രയോഗിച്ചല്ലോ? (വരി 61). ഇങ്ങനെ ഒരു ഏകദത്തിന്റെ
നിര്വചനത്തില് അതേ ഏകത്തിന്റെ പ്രയോഗം വരുന്നതിന്
പര്യാവര്ത്തനം (recursion) എന്ന് പറയുന്നു. ഇത് പ്രോഗ്രാമിംഗ് ചെയ്യുന്ന
ഒട്ടേറെപ്പേര് അതിശയത്തോടെ (ഭയബഹുമാനങ്ങളോടെ!) മാത്രം നോക്കിക്കാണുന്ന ഒരു
കാര്യമാണ്. ഈ സ്ഥിതിവിശേഷത്തെ ആസ്പദമാക്കി "To iterate is human; to
recurse, divine." എന്ന ഒരു ചൊല്ലുതന്നെയുണ്ട് ("ആവര്ത്തനം മാനുഷികമാണ്;
പര്യാവര്ത്തനമോ, ദൈവീകവും.").
പര്യാവര്ത്തനത്തിന്റെ ആശയം ശരിയായി മനസ്സിലാക്കിയില്ലെങ്കില് അത് ഉപയോഗിച്ച് എഴുതുന്ന പ്രോഗ്രാം അത്യതിശയകരമാണെന്ന് തോന്നാം ( മുകളിലത്തെ
selection_sort
എന്ന ഏകദത്തില് "ശരിക്കും" എവിടെയാണ് ക്രമപ്പെടുത്തല്
നടക്കുന്നത്? എന്നത് വളരെ സാധാരണമായ ഒരു സംശയമാണ്.). എന്നാല് പല
പ്രവര്ത്തനരീതികളും (അല്ഗോരിതങ്ങളും) വിശദീകരിക്കാനും മനസ്സിലാക്കാനും ഏറ്റവും
ലളിതമായ വഴി അവ പര്യാവര്ത്തന രീതിയില് എഴുതുകയെന്നതാണ്. ഈ പാഠത്തില്
തെരഞ്ഞെടുക്കല് ക്രമീകരണം നടപ്പിലാക്കാന് എഴുതിയ
selection_sort
എന്ന ഏകദവും അതിന്റെ വിശദീകരണവും നന്നായി
മനസ്സിലാക്കിയാല് ഒട്ടേറെ പ്രോഗ്രാമര്മാര്ക്ക് ബാലികേറാമലയായ
പര്യാവര്ത്തനത്തെ മനസ്സിലാക്കുന്നതില് നിങ്ങള് നല്ല തുടക്കമിട്ടു എന്നര്ത്ഥം.
അതുകൊണ്ട് സംശയങ്ങളുണ്ടെങ്കില് കമന്റുകളായി ചോദിക്കാന് മടിക്കരുത്.
കുറിപ്പ്
1. "Argument" എന്ന ഇംഗ്ളീഷ് വാക്കിന്റെ ഈ അര്ത്ഥത്തിലുള്ള പ്രയോഗം
ലാറ്റിന് ഭാഷയിലെ "to put in clear light; to declare" എന്നര്ത്ഥം വരുന്ന
"arguere" എന്ന പദത്തില്നിന്നാണെന്ന് കാണുന്നു . സംസ്കൃതത്തിലെ वाक्य्: ശബ്ദത്തിന് ഈ അര്ത്ഥങ്ങളും ഉള്ളതുകൊണ്ട് — മോണിയര്-വില്യംസ് നിഘണ്ടു കാണുക — function argument എന്നതിന് "ഏകദത്തിന്റെ വാക്യം" എന്ന് പ്രയോഗിച്ചിരിക്കുന്നു. ↩
0 comments: