Algorithmic Thinking (Part 1)

Brought by: Coursera

Overview

Experienced Computer Scientists analyze and solve computational problems at a level of abstraction that is beyond that of any particular programming language. This two-part course builds on the principles that you learned in our Principles of Computing course and is designed to train students in the mathematical concepts and process of "Algorithmic Thinking", allowing them to build simpler, more efficient solutions to real-world computational problems.

In part 1 of this course, we will study the notion of algorithmic efficiency and consider its application to several problems from graph theory. As the central part of the course, students will implement several important graph algorithms in Python and then use these algorithms to analyze two large real-world data sets. The main focus of these tasks is to understand interaction between the algorithms and the structure of the data sets being analyzed by these algorithms.

Recommended Background - Students should be comfortable writing intermediate size (300+ line) programs in Python and have a basic understanding of searching, sorting, and recursion. Students should also have a solid math background that includes algebra, pre-calculus and a familiarity with the math concepts covered in "Principles of Computing".

Syllabus

  • Module 1 - Core Materials
    • What is Algorithmic Thinking?, class structure, graphs, brute-force algorithms
  • Modules 1 - Project and Application
    • Graph representations, plotting, analysis of citation graphs
  • Module 2 - Core Materials
    • Asymptotic analysis, "big O" notation, pseudocode, breadth-first search
  • Module 2 - Project and Application
    • Connected components, graph resilience, and analysis of computer networks

Taught by

Luay Nakhleh, Scott Rixner and Joe Warren

Algorithmic Thinking (Part 1)
Go to course

Algorithmic Thinking (Part 1)

Brought by: Coursera

  • Coursera
  • Free
  • English
  • Certificate Available
  • Available at any time
  • intermediate
  • Arabic, French, Portuguese, Italian, German, Russian, English, Spanish, Korean, Telugu, Greek, Thai, Indonesian, Kazakh, Hindi, Swedish, Chinese, Ukrainian, Japanese, Polish, Dutch, Turkish
8.1.2PHP Version719msRequest Duration2MBMemory UsageGET en/courses/{slug}Route
    • Booting (445ms)
    • Application (273ms)
    • 1 x Booting (61.83%)
      444.53ms
      1 x Application (37.92%)
      272.61ms
      14 templates were rendered
      • public.courses.show (resources/views/public/courses/show.blade.php)3bladefile
        Params
        0
        course
        1
        links
        2
        config
      • public.courses.partials.breadcrumbs (resources/views/public/courses/partials/breadcrumbs.blade.php)6bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
      • public.courses.partials.heading (resources/views/public/courses/partials/heading.blade.php)7bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
        6
        classes
      • public.courses.partials.details (resources/views/public/courses/partials/details.blade.php)6bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
      • public.courses.partials.breadcrumbs (resources/views/public/courses/partials/breadcrumbs.blade.php)6bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
      • public.courses.partials.heading (resources/views/public/courses/partials/heading.blade.php)7bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
        6
        classes
      • public.layouts.main (resources/views/public/layouts/main.blade.php)6bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
      • public.layouts.partials.meta (resources/views/public/layouts/partials/meta.blade.php)6bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
      • public.layouts.partials.navbar (resources/views/public/layouts/partials/navbar.blade.php)6bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
      • public.auth.profile.partials.links (resources/views/public/auth/profile/partials/links.blade.php)6bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
      • public.auth.profile.partials.link (resources/views/public/auth/profile/partials/link.blade.php)8bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
        6
        route
        7
        title
      • public.auth.profile.partials.link (resources/views/public/auth/profile/partials/link.blade.php)8bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
        6
        route
        7
        title
      • public.auth.profile.partials.link (resources/views/public/auth/profile/partials/link.blade.php)8bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
        6
        route
        7
        title
      • public.layouts.partials.flash-session (resources/views/public/layouts/partials/flash-session.blade.php)6bladefile
        Params
        0
        __env
        1
        app
        2
        errors
        3
        course
        4
        links
        5
        config
      uri
      GET en/courses/{slug}
      middleware
      web, localize:en
      controller
      App\Http\Controllers\CourseController@show
      as
      en.courses.show
      namespace
      prefix
      /en
      where
      file
      app/Http/Controllers/CourseController.php:17-35
      7 statements were executed7.02ms
      • select * from `courses` where `slug_en` = 'algorithmic-thinking-(part-1)' limit 1
        5.07ms/app/Http/Controllers/CourseController.php:20corspedia
        Metadata
        Bindings
        • 0. algorithmic-thinking-(part-1)
        Backtrace
        • 17. /app/Http/Controllers/CourseController.php:20
        • 18. /vendor/laravel/framework/src/Illuminate/Routing/Controller.php:54
        • 19. /vendor/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php:43
        • 20. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:260
        • 21. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:205
      • update `courses` set `visitors` = `visitors` + 1, `courses`.`updated_at` = '2025-06-11 03:39:13' where `id` = 56
        750μs/app/Http/Controllers/CourseController.php:21corspedia
        Metadata
        Bindings
        • 0. 2025-06-11 03:39:13
        • 1. 56
        Backtrace
        • 17. /app/Http/Controllers/CourseController.php:21
        • 18. /vendor/laravel/framework/src/Illuminate/Routing/Controller.php:54
        • 19. /vendor/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php:43
        • 20. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:260
        • 21. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:205
      • select `id`, `name_en`, `name_ar`, `topic_id`, `slug_en`, `slug_ar` from `subjects` where `subjects`.`id` in (6)
        260μs/app/Http/Controllers/CourseController.php:23corspedia
        Metadata
        Backtrace
        • 20. /app/Http/Controllers/CourseController.php:23
        • 21. /vendor/laravel/framework/src/Illuminate/Routing/Controller.php:54
        • 22. /vendor/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php:43
        • 23. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:260
        • 24. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:205
      • select `id`, `name_en`, `name_ar`, `slug_en`, `slug_ar` from `topics` where `topics`.`id` in (1)
        210μs/app/Http/Controllers/CourseController.php:23corspedia
        Metadata
        Backtrace
        • 25. /app/Http/Controllers/CourseController.php:23
        • 26. /vendor/laravel/framework/src/Illuminate/Routing/Controller.php:54
        • 27. /vendor/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php:43
        • 28. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:260
        • 29. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:205
      • select * from `institutions` where `institutions`.`id` in (12) and `institutions`.`deleted_at` is null
        230μs/app/Http/Controllers/CourseController.php:23corspedia
        Metadata
        Backtrace
        • 20. /app/Http/Controllers/CourseController.php:23
        • 21. /vendor/laravel/framework/src/Illuminate/Routing/Controller.php:54
        • 22. /vendor/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php:43
        • 23. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:260
        • 24. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:205
      • select * from `providers` where `providers`.`id` in (2) and `providers`.`deleted_at` is null
        230μs/app/Http/Controllers/CourseController.php:23corspedia
        Metadata
        Backtrace
        • 20. /app/Http/Controllers/CourseController.php:23
        • 21. /vendor/laravel/framework/src/Illuminate/Routing/Controller.php:54
        • 22. /vendor/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php:43
        • 23. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:260
        • 24. /vendor/laravel/framework/src/Illuminate/Routing/Route.php:205
      • select * from `html_files` where `html_files`.`id` = 56 limit 1
        270μs/app/Models/Course.php:84corspedia
        Metadata
        Bindings
        • 0. 56
        Backtrace
        • 21. /app/Models/Course.php:84
        • 28. view::public.courses.show:29
        • 30. /vendor/laravel/framework/src/Illuminate/Filesystem/Filesystem.php:125
        • 31. /vendor/laravel/framework/src/Illuminate/View/Engines/PhpEngine.php:58
        • 32. /vendor/laravel/framework/src/Illuminate/View/Engines/CompilerEngine.php:72
      App\Models\HtmlFile
      1
      App\Models\Provider
      1
      App\Models\Institution
      1
      App\Models\Topic
      1
      App\Models\Subject
      1
      App\Models\Course
      1
        _token
        iFfdHkh4b1RxEvzPsmvI9qRYfFv2SIPIOdVkEM8n
        locale
        en
        _previous
        array:1 [ "url" => "https://www.corspedia.com/en/courses/algorithmic-thinking-%28part-1%29" ]
        _flash
        array:2 [ "old" => [] "new" => [] ]
        PHPDEBUGBAR_STACK_DATA
        []
        path_info
        /en/courses/algorithmic-thinking-%28part-1%29
        status_code
        200
        
        status_text
        OK
        format
        html
        content_type
        text/html; charset=UTF-8
        request_query
        []
        
        request_request
        []
        
        request_headers
        0 of 0
        array:24 [ "cf-ipcountry" => array:1 [ 0 => "US" ] "cf-connecting-ip" => array:1 [ 0 => "216.73.216.84" ] "cdn-loop" => array:1 [ 0 => "cloudflare; loops=1" ] "x-forwarded-proto" => array:1 [ 0 => "https" ] "x-forwarded-for" => array:1 [ 0 => "216.73.216.84" ] "sec-fetch-site" => array:1 [ 0 => "none" ] "accept" => array:1 [ 0 => "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7" ] "user-agent" => array:1 [ 0 => "Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)" ] "upgrade-insecure-requests" => array:1 [ 0 => "1" ] "sec-ch-ua-platform" => array:1 [ 0 => ""Windows"" ] "sec-ch-ua-mobile" => array:1 [ 0 => "?0" ] "sec-ch-ua" => array:1 [ 0 => ""Chromium";v="130", "HeadlessChrome";v="130", "Not?A_Brand";v="99"" ] "cache-control" => array:1 [ 0 => "no-cache" ] "pragma" => array:1 [ 0 => "no-cache" ] "sec-fetch-dest" => array:1 [ 0 => "document" ] "cf-ray" => array:1 [ 0 => "94de147eeaa5eb66-ORD" ] "accept-encoding" => array:1 [ 0 => "gzip, br" ] "priority" => array:1 [ 0 => "u=0, i" ] "sec-fetch-user" => array:1 [ 0 => "?1" ] "sec-fetch-mode" => array:1 [ 0 => "navigate" ] "cf-visitor" => array:1 [ 0 => "{"scheme":"https"}" ] "host" => array:1 [ 0 => "www.corspedia.com" ] "content-length" => array:1 [ 0 => "" ] "content-type" => array:1 [ 0 => "" ] ]
        request_server
        0 of 0
        array:50 [ "USER" => "www-data" "HOME" => "/var/www" "HTTP_CF_IPCOUNTRY" => "US" "HTTP_CF_CONNECTING_IP" => "216.73.216.84" "HTTP_CDN_LOOP" => "cloudflare; loops=1" "HTTP_X_FORWARDED_PROTO" => "https" "HTTP_X_FORWARDED_FOR" => "216.73.216.84" "HTTP_SEC_FETCH_SITE" => "none" "HTTP_ACCEPT" => "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7" "HTTP_USER_AGENT" => "Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)" "HTTP_UPGRADE_INSECURE_REQUESTS" => "1" "HTTP_SEC_CH_UA_PLATFORM" => ""Windows"" "HTTP_SEC_CH_UA_MOBILE" => "?0" "HTTP_SEC_CH_UA" => ""Chromium";v="130", "HeadlessChrome";v="130", "Not?A_Brand";v="99"" "HTTP_CACHE_CONTROL" => "no-cache" "HTTP_PRAGMA" => "no-cache" "HTTP_SEC_FETCH_DEST" => "document" "HTTP_CF_RAY" => "94de147eeaa5eb66-ORD" "HTTP_ACCEPT_ENCODING" => "gzip, br" "HTTP_PRIORITY" => "u=0, i" "HTTP_SEC_FETCH_USER" => "?1" "HTTP_SEC_FETCH_MODE" => "navigate" "HTTP_CF_VISITOR" => "{"scheme":"https"}" "HTTP_HOST" => "www.corspedia.com" "REDIRECT_STATUS" => "200" "SERVER_NAME" => "corspedia.com" "SERVER_PORT" => "443" "SERVER_ADDR" => "141.95.147.152" "REMOTE_USER" => "" "REMOTE_PORT" => "48726" "REMOTE_ADDR" => "172.70.100.11" "SERVER_SOFTWARE" => "nginx/1.18.0" "GATEWAY_INTERFACE" => "CGI/1.1" "HTTPS" => "on" "REQUEST_SCHEME" => "https" "SERVER_PROTOCOL" => "HTTP/2.0" "DOCUMENT_ROOT" => "/var/www/corspedia/public" "DOCUMENT_URI" => "/index.php" "REQUEST_URI" => "/en/courses/algorithmic-thinking-%28part-1%29" "SCRIPT_NAME" => "/index.php" "CONTENT_LENGTH" => "" "CONTENT_TYPE" => "" "REQUEST_METHOD" => "GET" "QUERY_STRING" => "" "SCRIPT_FILENAME" => "/var/www/corspedia/public/index.php" "PATH_INFO" => "" "FCGI_ROLE" => "RESPONDER" "PHP_SELF" => "/index.php" "REQUEST_TIME_FLOAT" => 1749613153.3643 "REQUEST_TIME" => 1749613153 ]
        request_cookies
        []
        
        response_headers
        0 of 0
        array:5 [ "content-type" => array:1 [ 0 => "text/html; charset=UTF-8" ] "cache-control" => array:1 [ 0 => "no-cache, private" ] "date" => array:1 [ 0 => "Wed, 11 Jun 2025 03:39:13 GMT" ] "set-cookie" => array:2 [ 0 => "XSRF-TOKEN=eyJpdiI6ImVzRWExRjhUN1FZL0E0V0VJdWpPckE9PSIsInZhbHVlIjoic3hDTld3QXNKcStqUGxsMkE5TXprbWh1OHZ1Vlh1dXlqclhwako2WFBHSmV3VUJrOU9jNitIM0dYUGhFbHNJUTdlRXNGTnNqdEhsaE9TbTFoYVJzdE0xT2RRbm41SUFDdHBPMjNYbjJNR2ZNL0FiU250YVdJL0VYcDIwWElJejAiLCJtYWMiOiI1MjEyZjc2NmNjZDZiMmU5NjlkNzk1OGFmMTZiYmU0ZDEzOTRlODM3OGQ1MTQ4MmUyZDEzZjY0ZDZlMTMwNzBmIiwidGFnIjoiIn0%3D; expires=Wed, 11 Jun 2025 05:39:14 GMT; Max-Age=7200; path=/; samesite=laxXSRF-TOKEN=eyJpdiI6ImVzRWExRjhUN1FZL0E0V0VJdWpPckE9PSIsInZhbHVlIjoic3hDTld3QXNKcStqUGxsMkE5TXprbWh1OHZ1Vlh1dXlqclhwako2WFBHSmV3VUJrOU9jNitIM0dYUGhFbHNJUTdlRXNGT" 1 => "laravel_session=eyJpdiI6IkE5MWFwUFMxMmJiUE1lb2tYUnNZOGc9PSIsInZhbHVlIjoiN25yRVNtcWk2MFlBbGd5Q1pjZDN2WXlqcVRwNmh6dnlLRkZ2b2d1NG1DeVlKT3Rla0g5R3Vuak9lcGNaVFVLV2Fnc1B5dzNvRmN5SytRUno2WUpaNlpFUkd3QWtsVUVLT2U2QXdrZkJvUkFybUlVWjlDTkV3RC9xODIxeHpEKzIiLCJtYWMiOiI3NTRjNTY0YzllMjdhM2Q3ZjdhN2U1OWQ1YjM5MTEwYTM1NTEyNjI4NmM3MjRmZTE4YmZjZmQxOTM5NDJhNDViIiwidGFnIjoiIn0%3D; expires=Wed, 11 Jun 2025 05:39:14 GMT; Max-Age=7200; path=/; httponly; samesite=laxlaravel_session=eyJpdiI6IkE5MWFwUFMxMmJiUE1lb2tYUnNZOGc9PSIsInZhbHVlIjoiN25yRVNtcWk2MFlBbGd5Q1pjZDN2WXlqcVRwNmh6dnlLRkZ2b2d1NG1DeVlKT3Rla0g5R3Vuak9lcGNaVFVLV2Fn" ] "Set-Cookie" => array:2 [ 0 => "XSRF-TOKEN=eyJpdiI6ImVzRWExRjhUN1FZL0E0V0VJdWpPckE9PSIsInZhbHVlIjoic3hDTld3QXNKcStqUGxsMkE5TXprbWh1OHZ1Vlh1dXlqclhwako2WFBHSmV3VUJrOU9jNitIM0dYUGhFbHNJUTdlRXNGTnNqdEhsaE9TbTFoYVJzdE0xT2RRbm41SUFDdHBPMjNYbjJNR2ZNL0FiU250YVdJL0VYcDIwWElJejAiLCJtYWMiOiI1MjEyZjc2NmNjZDZiMmU5NjlkNzk1OGFmMTZiYmU0ZDEzOTRlODM3OGQ1MTQ4MmUyZDEzZjY0ZDZlMTMwNzBmIiwidGFnIjoiIn0%3D; expires=Wed, 11-Jun-2025 05:39:14 GMT; path=/XSRF-TOKEN=eyJpdiI6ImVzRWExRjhUN1FZL0E0V0VJdWpPckE9PSIsInZhbHVlIjoic3hDTld3QXNKcStqUGxsMkE5TXprbWh1OHZ1Vlh1dXlqclhwako2WFBHSmV3VUJrOU9jNitIM0dYUGhFbHNJUTdlRXNGT" 1 => "laravel_session=eyJpdiI6IkE5MWFwUFMxMmJiUE1lb2tYUnNZOGc9PSIsInZhbHVlIjoiN25yRVNtcWk2MFlBbGd5Q1pjZDN2WXlqcVRwNmh6dnlLRkZ2b2d1NG1DeVlKT3Rla0g5R3Vuak9lcGNaVFVLV2Fnc1B5dzNvRmN5SytRUno2WUpaNlpFUkd3QWtsVUVLT2U2QXdrZkJvUkFybUlVWjlDTkV3RC9xODIxeHpEKzIiLCJtYWMiOiI3NTRjNTY0YzllMjdhM2Q3ZjdhN2U1OWQ1YjM5MTEwYTM1NTEyNjI4NmM3MjRmZTE4YmZjZmQxOTM5NDJhNDViIiwidGFnIjoiIn0%3D; expires=Wed, 11-Jun-2025 05:39:14 GMT; path=/; httponlylaravel_session=eyJpdiI6IkE5MWFwUFMxMmJiUE1lb2tYUnNZOGc9PSIsInZhbHVlIjoiN25yRVNtcWk2MFlBbGd5Q1pjZDN2WXlqcVRwNmh6dnlLRkZ2b2d1NG1DeVlKT3Rla0g5R3Vuak9lcGNaVFVLV2Fn" ] ]
        session_attributes
        0 of 0
        array:5 [ "_token" => "iFfdHkh4b1RxEvzPsmvI9qRYfFv2SIPIOdVkEM8n" "locale" => "en" "_previous" => array:1 [ "url" => "https://www.corspedia.com/en/courses/algorithmic-thinking-%28part-1%29" ] "_flash" => array:2 [ "old" => [] "new" => [] ] "PHPDEBUGBAR_STACK_DATA" => [] ]