{"id":3230,"date":"2022-06-29T22:52:10","date_gmt":"2022-06-29T19:52:10","guid":{"rendered":"https:\/\/demensdeum.com\/blog\/?p=3230"},"modified":"2024-12-16T22:32:19","modified_gmt":"2024-12-16T19:32:19","slug":"sleep-sort","status":"publish","type":"post","link":"https:\/\/demensdeum.com\/blog\/ru\/2022\/06\/29\/sleep-sort\/","title":{"rendered":"Sleep Sort"},"content":{"rendered":"<p>Sleep Sort &#8211; \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430 \u0441\u043d\u043e\u043c, \u0435\u0449\u0435 \u043e\u0434\u0438\u043d \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u0442\u0435\u043b\u044c \u0434\u0435\u0442\u0435\u0440\u043c\u0435\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0445 \u0441\u0442\u0440\u0430\u043d\u043d\u044b\u0445 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u043e\u0432 \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0438.<\/p>\n<p>\u0420\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<\/p>\n<ol>\n<li>\u041f\u0440\u043e\u0445\u043e\u0434\u0438\u0442 \u0446\u0438\u043a\u043b\u043e\u043c \u043f\u043e \u0441\u043f\u0438\u0441\u043a\u0443 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432<\/li>\n<li>\u0414\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0446\u0438\u043a\u043b\u0430 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u043f\u043e\u0442\u043e\u043a<\/li>\n<li>\u0412 \u043f\u043e\u0442\u043e\u043a\u0435 \u0448\u0435\u0434\u0443\u043b\u0438\u0442\u0441\u044f \u0441\u043e\u043d (sleep) \u043f\u043e\u0442\u043e\u043a\u0430 \u043d\u0430 \u0432\u0440\u0435\u043c\u044f &#8211; \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0438 \u0432\u044b\u0432\u043e\u0434 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043f\u043e\u0441\u043b\u0435 \u0441\u043d\u0430<\/li>\n<li>\u041f\u043e \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044e \u0446\u0438\u043a\u043b\u0430, \u0436\u0434\u0435\u043c \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044f \u0441\u0430\u043c\u043e\u0433\u043e \u0434\u043e\u043b\u0433\u043e\u0433\u043e \u0441\u043d\u0430 \u043f\u043e\u0442\u043e\u043a\u0430, \u0432\u044b\u0432\u043e\u0434\u0438\u043c \u043e\u0442\u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0441\u043f\u0438\u0441\u043e\u043a<\/li>\n<\/ol>\n<p>\u041f\u0440\u0438\u043c\u0435\u0440 \u043a\u043e\u0434\u0430 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430 \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0438 \u0441\u043d\u043e\u043c \u043d\u0430 C:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-unknown\" data-lang=\"unknown\"><code>#include &lt;stdlib.h&gt;\n#include &lt;pthread.h&gt;\n#include &lt;unistd.h&gt;\n\ntypedef struct {\n    int number;\n} ThreadPayload;\n\nvoid *sortNumber(void *args) {\n    ThreadPayload *payload = (ThreadPayload*) args;\n    const int number = payload-&gt;number;\n    free(payload);\n    usleep(number * 1000);\n    printf(\"%d \", number);\n    return NULL;\n}\n\nint main(int argc, char *argv[]) {\n    const int numbers[] = {2, 42, 1, 87, 7, 9, 5, 35};\n    const int length = sizeof(numbers) \/ sizeof(int);\n\n    int maximal = 0;\n    pthread_t maximalThreadID;\n\n    printf(\"Sorting: \");\n    for (int i = 0; i &lt; length; i++) { pthread_t threadID; int number = numbers[i]; printf(\"%d \", number); ThreadPayload *payload = malloc(sizeof(ThreadPayload)); payload-&gt;number = number;\n        pthread_create(&amp;threadID, NULL, sortNumber, (void *) payload);\n        if (maximal &lt; number) {\n            maximal = number;\n            maximalThreadID = threadID;\n        }\n    }\n    printf(\"\\n\");\n    printf(\"Sorted: \");\n    pthread_join(maximalThreadID, NULL);\n    printf(\"\\n\");\n    return 0;\n}\n<\/code><\/pre>\n<\/div>\n<p>\u0412 \u044d\u0442\u043e\u0439 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u044f \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b \u0444\u0443\u043d\u043a\u0446\u0438\u044e usleep \u043d\u0430 \u043c\u0438\u043a\u0440\u043e\u0441\u0435\u043a\u0443\u043d\u0434\u0430\u0445 \u0441 \u0443\u043c\u043d\u043e\u0436\u0435\u043d\u0438\u0435\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043d\u0430 1000, \u0442.\u0435. \u043d\u0430 \u043c\u0438\u043b\u043b\u0438\u0441\u0435\u043a\u0443\u043d\u0434\u0430\u0445.<br \/>\u0412\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u0430 &#8211; <strong>O(\u043e\u0447. \u0434\u043e\u043b\u0433\u043e)<\/strong><\/p>\n<h3>\u0421\u0441\u044b\u043b\u043a\u0438<\/h3>\n<p><a href=\"https:\/\/gitlab.com\/demensdeum\/algorithms\/-\/tree\/master\/sortAlgorithms\/sleepSort\" rel=\"noopener\" target=\"_blank\">https:\/\/gitlab.com\/demensdeum\/algorithms\/-\/tree\/master\/sortAlgorithms\/sleepSort<\/a><\/p>\n<h3>\u0418\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0438<\/h3>\n<p><a href=\"https:\/\/codoholicconfessions.wordpress.com\/2017\/05\/21\/strangest-sorting-algorithms\/\" rel=\"noopener\" target=\"_blank\">https:\/\/codoholicconfessions.wordpress.com\/2017\/05\/21\/strangest-sorting-algorithms\/<\/a><br \/><a href=\"https:\/\/twitter.com\/javascriptdaily\/status\/856267407106682880?lang=en\" rel=\"noopener\" target=\"_blank\">https:\/\/twitter.com\/javascriptdaily\/status\/856267407106682880?lang=en<\/a><br \/>\n<a href=\"https:\/\/stackoverflow.com\/questions\/6474318\/what-is-the-time-complexity-of-the-sleep-sort\" rel=\"noopener\" target=\"_blank\">https:\/\/stackoverflow.com\/questions\/6474318\/what-is-the-time-complexity-of-the-sleep-sort<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Sleep Sort &#8211; \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0430 \u0441\u043d\u043e\u043c, \u0435\u0449\u0435 \u043e\u0434\u0438\u043d \u043f\u0440\u0435\u0434\u0441\u0442\u0430\u0432\u0438\u0442\u0435\u043b\u044c \u0434\u0435\u0442\u0435\u0440\u043c\u0435\u043d\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0445 \u0441\u0442\u0440\u0430\u043d\u043d\u044b\u0445 \u0430\u043b\u0433\u043e\u0440\u0438\u0442\u043c\u043e\u0432 \u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u043a\u0438. \u0420\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c: \u041f\u0440\u043e\u0445\u043e\u0434\u0438\u0442 \u0446\u0438\u043a\u043b\u043e\u043c \u043f\u043e \u0441\u043f\u0438\u0441\u043a\u0443 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u043e\u0432 \u0414\u043b\u044f \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0446\u0438\u043a\u043b\u0430 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0439 \u043f\u043e\u0442\u043e\u043a \u0412 \u043f\u043e\u0442\u043e\u043a\u0435 \u0448\u0435\u0434\u0443\u043b\u0438\u0442\u0441\u044f \u0441\u043e\u043d (sleep) \u043f\u043e\u0442\u043e\u043a\u0430 \u043d\u0430 \u0432\u0440\u0435\u043c\u044f &#8211; \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0438 \u0432\u044b\u0432\u043e\u0434 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043f\u043e\u0441\u043b\u0435 \u0441\u043d\u0430 \u041f\u043e \u043e\u043a\u043e\u043d\u0447\u0430\u043d\u0438\u044e \u0446\u0438\u043a\u043b\u0430, \u0436\u0434\u0435\u043c \u043e\u0436\u0438\u0434\u0430\u043d\u0438\u044f \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0438\u044f \u0441\u0430\u043c\u043e\u0433\u043e \u0434\u043e\u043b\u0433\u043e\u0433\u043e \u0441\u043d\u0430 \u043f\u043e\u0442\u043e\u043a\u0430, \u0432\u044b\u0432\u043e\u0434\u0438\u043c \u043e\u0442\u0441\u043e\u0440\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0441\u043f\u0438\u0441\u043e\u043a<a class=\"more-link\" href=\"https:\/\/demensdeum.com\/blog\/ru\/2022\/06\/29\/sleep-sort\/\">Continue reading <span class=\"screen-reader-text\">&#8220;Sleep Sort&#8221;<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[61,52],"tags":[131,194,190],"class_list":["post-3230","post","type-post","status-publish","format-standard","hentry","category-techie","category-tutorials","tag-algorithms","tag-sleep-sort","tag-sorting","entry"],"translation":{"provider":"WPGlobus","version":"3.0.2","language":"ru","enabled_languages":["en","ru","zh","de","fr","ja","pt"],"languages":{"en":{"title":true,"content":true,"excerpt":false},"ru":{"title":true,"content":true,"excerpt":false},"zh":{"title":true,"content":true,"excerpt":false},"de":{"title":true,"content":true,"excerpt":false},"fr":{"title":true,"content":true,"excerpt":false},"ja":{"title":true,"content":true,"excerpt":false},"pt":{"title":true,"content":true,"excerpt":false}}},"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/demensdeum.com\/blog\/ru\/wp-json\/wp\/v2\/posts\/3230","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/demensdeum.com\/blog\/ru\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/demensdeum.com\/blog\/ru\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/demensdeum.com\/blog\/ru\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/demensdeum.com\/blog\/ru\/wp-json\/wp\/v2\/comments?post=3230"}],"version-history":[{"count":10,"href":"https:\/\/demensdeum.com\/blog\/ru\/wp-json\/wp\/v2\/posts\/3230\/revisions"}],"predecessor-version":[{"id":3876,"href":"https:\/\/demensdeum.com\/blog\/ru\/wp-json\/wp\/v2\/posts\/3230\/revisions\/3876"}],"wp:attachment":[{"href":"https:\/\/demensdeum.com\/blog\/ru\/wp-json\/wp\/v2\/media?parent=3230"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/demensdeum.com\/blog\/ru\/wp-json\/wp\/v2\/categories?post=3230"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/demensdeum.com\/blog\/ru\/wp-json\/wp\/v2\/tags?post=3230"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}