পাইথন দিয়ে প্রোগ্রামিং শেখা ৩য় খণ্ড : ডেটা স্ট্রাকচার ও অ্যালগরিদম পরিচিতি

৳ 260.00

বইয়ের বিবরনী

শিরোনাম পাইথন দিয়ে প্রোগ্রামিং শেখ ৩য় খণ্ড
লেখক তামিম শাহ‍্‍রিয়ার সুবিন
ক্যাটেগরি কম্পিউটার প্রোগ্রামিং
ISBN 978-984-34-3693-1
সংস্করন প্রথম প্রকাশ, ফেব্রুয়ারী, ২০১৮
পৃষ্ঠাসংখ্যা ১৮৫

লেখক পরিচিতি

তামিম শাহ‍্‍রিয়ার সুবিন

তামিম শাহ‍্‍রিয়ার (ডাকনাম : সুবিন)-এর জন্ম ১৯৮২ সালের ৭ নভেম্বর ময়মনসিংহে। গ্রামের বাড়ি কুমিল্লা জেলার চান্দিনা উপজেলার হারং গ্রামে। তাঁর বাবা মো: মোজাম্মেল হক ছিলেন সরকারি কর্মকর্তা এবং মা ফেরদৌসি বেগম গৃহিণী। স্ত্রী সিরাজুম মুনিরা ও পুত্র আরাভ শাহরিয়ারকে নিয়ে বর্তমানে সিঙ্গাপুরে বসবাস করছেন।

লেখাপড়া করেছেন হোমনা সরকারি প্রাথমিক বিদ্যালয়, এ কে উচ্চ বিদ্যালয়, নটর ডেম কলেজ এবং শাহজালাল বিজ্ঞান ও প্রযুক্তি বিশ্ববিদ্যালয়ে। ২০০৬ সালে শাহজালাল বিজ্ঞান ও প্রযুক্তি বিশ্ববিদ্যালয়ে কম্পিউটার সায়েন্স ও ইঞ্জিনিয়ারিং বিভাগ থেকে পাস করেছেন। বিশ্ববিদ্যালয়ে থাকাকালীন বিভিন্ন প্রোগ্রামিং প্রতিযোগিতায় অংশগ্রহণ করেছেন। পরবর্তী সময়ে (২০০৭ ও ২০০৮ সালে) তিনি এসিএম আইসিপিসি ঢাকা রিজিওনাল-এর বিচারক ছিলেন। একটি বেসরকারি বিশ্ববিদ্যালয়ে শিক্ষকতা দিয়ে কর্মজীবন শুরু করলেও পরে সফটওয়্যার প্রকৌশলী হিসেবে কাজ শুরু করেন। বাংলাদেশে থাকাকালীন সময়ে প্রতিষ্ঠা করেছেন মুক্ত সফটওয়্যার লিমিটেড ও দ্বিমিক কম্পিউটিং। এ ছাড়া তিনি বাংলাদেশ গণিত অলিম্পিয়াডে একজন একাডেমিক কাউন্সিলর। বর্তমানে সিঙ্গাপুরে গ্র্যাব নামক একটি আন্তর্জাতিক প্রতিষ্ঠানে ইঞ্জিনিয়ারিং ম্যানেজার হিসেবে কাজ করছেন।

Categories: ,

ভূমিকা

একজন সফটওয়্যার প্রকৌশলীর কাজ হচ্ছে সফটওয়্যার তৈরি করা। এই সফটওয়্যারের আবার নানান রকমফের রয়েছে― ছোটোখাটো মোবাইল কিংবা ওয়েব অ্যাপ্লিকেশন, যেমন― সফটওয়্যার, তেমনি কম্পিউটার চালানোর জন্য যে অপারেটিং সিস্টেম (উইন্ডোজ, লিনাক্স ইত্যাদি), চালকবিহীন গাড়ি নিয়ন্ত্রণের জন্য যে প্রোগ্রাম, সেগুলোও কিন্তু সফটওয়্যার। বাংলাদেশের সফটওয়্যার ইন্ডাস্ট্রিতে যে ধরনের কাজ হয়, তার বেশিরভাগই অপেক্ষাকৃত সহজ ও সাধারণ। এসব কাজ করার জন্য কম্পিউটার বিজ্ঞানের জ্ঞান খুব বেশি দরকার হয় না। কিন্তু কিছু কিছু কাজ করতে গেলে আবার কম্পিউটার বিজ্ঞানের জ্ঞান-বুদ্ধি অপরিহার্য। এসব জটিল সফটওয়্যার তৈরি করতে গেলে কম্পিউটার বিজ্ঞানের যে জিনিসটি না জানলেই নয়, তার নাম হচ্ছে ডেটা স্ট্রাকচার ও অ্যালগরিদম। ডেটা স্ট্রাকচার ও অ্যালগরিদম আলাদা জিনিস, কিন্তু তারা পরস্পরের সঙ্গে খুবই সম্পৃক্ত। তাই অনেক সময় বিষয় দুটো একই সঙ্গে উচ্চারিত হয়। এই বইতে আমি এই দুটো বিষয় নিয়েই লিখেছি।

পাইথন দিয়ে প্রোগ্রামিং শেখা সিরিজে আমি চেষ্টা করছি, একেবারে গোড়া থেকে শুরু করে কেউ যেন যোগ্য ও দক্ষ সফটওয়্যার নির্মাতা হিসেবে গড়ে ওঠে। প্রথম বইতে পাইথন দিয়ে প্রোগ্রামিং জগতের সঙ্গে পরিচয় করানো হয়েছে। দ্বিতীয় বইতে অবজেক্ট ওরিয়েন্টেড প্রোগ্রামিংয়ের সঙ্গে পরিচয় করানোর পাশাপাশি ওয়েব ক্রলিং শেখানো হয়েছে। এরপর শিক্ষার্থীরা যেন তাদের বেসিক প্রোগ্রামিং জ্ঞান আরো শক্ত করতে পারে, সেজন্য এই সিরিজের তৃতীয় বই― ডেটা স্ট্রাকচার ও অ্যালগরিদম পরিচিতি-তে আমি চেষ্টা করেছি পাঠকদেরকে প্রাথমিক ডেটা স্ট্রাকচার ও অ্যালগরিদমগুলোর সঙ্গে পরিচয় করিয়ে দিতে। এই বইতে যেটুকু দেখানো হয়েছে, তার বাইরেও আরো শিখতে হবে, কিন্তু এটুকু না জানলেই নয়। ডেটা স্ট্রাকচার ও অ্যালগরিদমের জ্ঞান কেবল শিক্ষার্থীদেরই কাজে লাগবে তা নয়, বরং যারা স্বশিক্ষিত প্রোগ্রামার বা সফটওয়্যার নির্মাতা, তাদের আরো কার্যকর হতে সাহায্য করবে।

এই বইটি রিভিউ করেছেন তাহমিদ রাফি, আবু আশরাফ মাসনুন, তানভীরুল ইসলাম, শহীদুল ইসলাম (সুমন), রুহুল আমীন (সজীব)। তাঁরা বেশ কিছু ভুলত্রুটি বের করার পাশাপাশি অনেক পরামর্শও দিয়েছেন, যা বইটিকে সমৃদ্ধ করেছে। তাই তাদের কাজে আমি কৃতজ্ঞ এবং পাশাপাশি পাঠকদের পক্ষ থেকেও তাঁরা বিশেষ ধন্যবাদ প্রাপ্য।

পাইথন একটি আধুনিক প্রোগ্রামিং ভাষা। এই ভাষা যেমন প্রোগ্রামিং শেখার ক্ষেত্রে অনেক সহায়ক, তেমনি বাস্তব জীবনেও নানা সফটওয়্যার তৈরিতে এর ব্যবহার ব্যাপক। ডেটা স্ট্রাকচার ও অ্যালগরিদম শেখার জন্যও যে পাইথন একটি ভালো প্রোগ্রামিং ভাষা― আশা করি এই বইটি পাঠকদের কাছে তা তুলে ধরতে সমর্থ হবে। সবাই আরো ভালো প্রোগ্রামার হিসেবে গড়ে উঠুক। সবার জন্য ভালোবাসা।

বইটি সম্পর্কে যে-কোনো মতামত ও পরামর্শ দিতে চাইলে আমাকে ইমেইল করা যাবে book@subeen.com ঠিকানায়।

তামিম শাহ‍্‍রিয়ার সুবিন,
আগস্ট ২০১৭।

 

সূচীপত্র

ভূমিকা

লেখক পরিচিতি

অধ্যায় ১ : ডেটা স্ট্রাকচার (Data Structure) ও অ্যালগরিদম (Algorithm)

  • ডেটা স্ট্রাকচার (Data Structure)
  • অ্যালগরিদম (Algorithm)
  • ডেটা স্ট্রাকচার ও অ্যালগরিদম কেন শিখব?
  • বইটি কাদের জন্য এবং কীভাবে পড়তে হবে?

অধ্যায় ২ : টাইম ও স্পেস কমপ্লেক্সিটি (Time & Space Complexity)

  • টাইম কমপ্লেক্সিটি (Time Complexity)
  • স্পেস কমপ্লেক্সিটি (Space Complexity)
  • কিছু উদাহরণ

অধ্যায় ৩ : কোড টেস্ট করার পদ্ধতি

  • প্রথম পদ্ধতি
  • assert-এর ব্যবহার
  • ইউনিট টেস্টিং

অধ্যায় ৪ : সার্চিং অ্যালগরিদম (Searching Algorithm)

  • লিনিয়ার সার্চ (Linear search)
  • বাইনারি সার্চ (Binary Search)

অধ্যায় ৫ : সর্টিং অ্যালগরিদম (Sorting Algorithm)

  • সিলেকশন সর্ট (Selection sort)
  • বাবল সর্ট (Bubble sort)
  • ইনসার্শন সর্ট (Insertion sort)

অধ্যায় ৬ : স্ট্যাক (Stack) ও কিউ (Queue)

  • স্ট্যাক (Stack)
  • কিউ (Queue)

অধ্যায় ৭ : লিংকড লিস্ট (Linked List)

  • লিংকড লিস্টের ধারণা
  • পাইথন দিয়ে লিংকড লিস্ট তৈরি
  • ডবলি লিংকড লিস্ট
  • লিংকড লিস্টের ব্যবহার

অধ্যায় ৮ : রিকার্শন

অধ্যায় ৯ : ট্রি (Tree)

  • বাইনারি ট্রি
  • ট্রি ট্রাভার্স করা

অধ্যায় ১০ : বাইনারি সার্চ ট্রি

অধ্যায় ১১ : হিপ, হিপ সর্ট ও প্রায়োরিটি কিউ

  • হিপ
  • হিপ সর্ট
  • প্রায়োরিটি কিউ (Priority Queue)

অধ্যায় ১২ : হ্যাশ টেবিল

অধ্যায় ১৩ : আরো সর্টিং অ্যালগরিদম

  • মার্জ সর্ট
  • কুইক সর্ট (Quick Sort)
  • কাউন্টিং সর্ট

অধ্যায় ১৪ : পাইথনের বিল্ট-ইন ডেটা স্ট্রাকচার

পরিশিষ্ট

  • গাণিতিক রাশির মান নির্ণয়
  • ইনফিক্স থেকে পোস্টফিক্সে রূপান্তর

Reviews

There are no reviews yet.

Be the first to review “পাইথন দিয়ে প্রোগ্রামিং শেখা ৩য় খণ্ড : ডেটা স্ট্রাকচার ও অ্যালগরিদম পরিচিতি”

Your email address will not be published. Required fields are marked *

Home
Course
Shop
Cart
Account
error: Content is protected !!