HIRASE CONNECTION WK

programming collection

目次

Blog 利用状況

ニュース

書庫

日記カテゴリ

Link Collection

[C++] シェーカーソート

シェーカーソート(シェーカーソート、Shaker sort、カクテルソート、Cocktail sort、双方向バブルソート、bidirectional bubble sort)。

バブルソートの改良版。バブルソートで1回のループで昇順と降順を一度に並び替える。同じ要素の並びは変わらない安定ソート。

template <typename TElement, typename TSize>
void ShakerSort(TElement * data, const TSize size)
{
    TSize head = 0;
    TSize tail = size - 1;
    while (head < tail)
    {
        TSize swapPos = head;

        for (TSize i = head; i < tail; ++i)
        {
            TElement diff = data[i] - data[i+1];
            if (diff > 0)
            {
                data[i  ] = data[i+1];
                data[i+1] = diff + data[i];
                swapPos = i;
            }
        }

        tail = swapPos;

        for (TSize i = tail; i > head; --i)
        {
            TElement diff = data[i] - data[i+1];
            if (diff > 0)
            {
                data[i  ] = data[i+1];
                data[i+1] = diff + data[i];
                swapPos = i;
            }
        }
        {    // TSizeがunsigned型の場合、対策。
            TSize i = head;
            TElement diff = data[i] - data[i+1];
            if (diff > 0)
            {
                data[i  ] = data[i+1];
                data[i+1] = diff + data[i];
                swapPos = i;
            }
        }
        head = swapPos;
    }
}

投稿日時 : 2008年5月8日 2:33

コメントを追加

# What's up to all, how is everything, I think every one is getting more from this web page, and your views are fastidious designed for new viewers. 2019/04/08 1:29 What's up to all, how is everything, I think every

What's up to all, how is everything, I think every one is getting more from this web page, and your views are fastidious designed for
new viewers.

# I've learn some just right stuff here. Definitely worth bookmarking for revisiting. I surprise how much effort you put to make this kind of wonderful informative site. 2019/05/01 20:35 I've learn some just right stuff here. Definitely

I've learn some just right stuff here. Definitely worth bookmarking for
revisiting. I surprise how much effort you put to make this kind of wonderful informative
site.

# This paragraph is truly a fastidious one it assists new web visitors, who are wishing for blogging. 2019/08/13 22:30 This paragraph is truly a fastidious one it assist

This paragraph is truly a fastidious one it
assists new web visitors, who are wishing for blogging.

# It's really very complicated in this busy life to listen news on TV, so I just use web for that purpose, and get the most up-to-date information. 2022/03/24 7:08 It's really very complicated in this busy life to

It's really very complicated in this busy life to
listen news on TV, so I just use web for that purpose, and get the most up-to-date information.

# It's really very complicated in this busy life to listen news on TV, so I just use web for that purpose, and get the most up-to-date information. 2022/03/24 7:09 It's really very complicated in this busy life to

It's really very complicated in this busy life to
listen news on TV, so I just use web for that purpose, and get the most up-to-date information.

# It's really very complicated in this busy life to listen news on TV, so I just use web for that purpose, and get the most up-to-date information. 2022/03/24 7:11 It's really very complicated in this busy life to

It's really very complicated in this busy life to
listen news on TV, so I just use web for that purpose, and get the most up-to-date information.

# It's really very complicated in this busy life to listen news on TV, so I just use web for that purpose, and get the most up-to-date information. 2022/03/24 7:12 It's really very complicated in this busy life to

It's really very complicated in this busy life to
listen news on TV, so I just use web for that purpose, and get the most up-to-date information.

# You actually make it seem really easy together with your presentation however I in finding this topic to be actually one thing that I feel I'd never understand. It seems too complex and extremely huge for me. I'm having a look ahead to your subsequent p 2022/06/04 5:07 You actually make it seem really easy together wit

You actually make it seem really easy together with your presentation however I in finding this topic to be actually one thing that I
feel I'd never understand. It seems too complex and extremely huge for me.
I'm having a look ahead to your subsequent post, I will try to get the cling of it!

# I am curious to find out what blog system you happen to be utilizing? I'm having some small security issues with my latest website and I'd like to find something more safe. Do you have any solutions? 2022/06/06 13:52 I am curious to find out what blog system you happ

I am curious to find out what blog system you happen to be utilizing?
I'm having some small security issues with my latest website and I'd
like to find something more safe. Do you have any solutions?

# Its like you read my mind! You seem to know a lot about this, like you wrote the book in it or something. I think that you could do with a few pics to drive the message home a bit, but instead of that, this is excellent blog. A great read. I'll definitely 2022/06/06 20:46 Its like you read my mind! You seem to know a lot

Its like you read my mind! You seem to know
a lot about this, like you wrote the book in it or something.
I think that you could do with a few pics to drive the message home a bit, but instead of
that, this is excellent blog. A great read. I'll definitely be back.

# If some one desires to be updated with hottest technologies then he must be pay a quick visit this site and be up to date daily. 2022/06/08 7:46 If some one desires to be updated with hottest tec

If some one desires to be updated with hottest technologies then he must be
pay a quick visit this site and be up to date daily.

# Hi, i think that i saw you visited my web site so i came to “return the favor”.I'm trying to find things to enhance my web site!I suppose its ok to use some of your ideas!! 2022/06/09 8:18 Hi, i think that i saw you visited my web site so

Hi, i think that i saw you visited my web site so i came to
“return the favor”.I'm trying to find things to enhance my web site!I suppose its ok to use some of your ideas!!

# I think this is one of the most significant info for me. And i'm glad reading your article. But should remark on few general things, The website style is wonderful, the articles is really great : D. Good job, cheers 2022/06/10 12:33 I think this is one of the most significant info f

I think this is one of the most significant info for me.
And i'm glad reading your article. But should remark on few general things, The website
style is wonderful, the articles is really great : D.
Good job, cheers

# Howdy just wanted to give you a quick heads up. The words in your post seem to be running off the screen in Chrome. I'm not sure if this is a formatting issue or something to do with web browser compatibility but I figured I'd post to let you know. The d 2022/06/14 12:47 Howdy just wanted to give you a quick heads up. Th

Howdy just wanted to give you a quick heads up. The words in your post seem to be running off the screen in Chrome.
I'm not sure if this is a formatting issue or
something to do with web browser compatibility but
I figured I'd post to let you know. The design and style
look great though! Hope you get the issue solved soon. Kudos

# I truly love your website.. Excellent colors & theme. Did you make this website yourself? Please reply back as I'm trying to create my own personal blog and want to find out where you got this from or exactly what the theme is called. Cheers! 2022/07/15 7:46 I truly love your website.. Excellent colors &

I truly love your website.. Excellent colors & theme. Did you make this website yourself?
Please reply back as I'm trying to create my own personal blog and
want to find out where you got this from or exactly what the theme is called.
Cheers!

# Why users still make use of to read news papers when in this technological globe the whole thing is existing on net? 2022/07/16 0:36 Why users still make use of to read news papers wh

Why users still make use of to read news papers when in this technological globe the whole thing is existing on net?

# hello!,I like your writing so so much! share we be in contact more about your post on AOL? I require an expert on this house to unravel my problem. Maybe that's you! Taking a look forward to see you. 2022/08/03 8:54 hello!,I like your writing so so much! share we be

hello!,I like your writing so so much! share we be in contact more about your
post on AOL? I require an expert on this house to unravel
my problem. Maybe that's you! Taking a look forward to see you.

# You really make it seem so easy with your presentation but I find this topic to be actually something that I think I would never understand. It seems too complicated and extremely broad for me. I'm looking forward for your next post, I'll try to get the 2022/08/08 22:58 You really make it seem so easy with your presenta

You really make it seem so easy with your presentation but
I find this topic to be actually something that I think I would never understand.
It seems too complicated and extremely broad for me.

I'm looking forward for your next post, I'll try to get the hang of it!

# You really make it seem so easy with your presentation but I find this topic to be actually something that I think I would never understand. It seems too complicated and extremely broad for me. I'm looking forward for your next post, I'll try to get the 2022/08/08 22:59 You really make it seem so easy with your presenta

You really make it seem so easy with your presentation but
I find this topic to be actually something that I think I would never understand.
It seems too complicated and extremely broad for me.

I'm looking forward for your next post, I'll try to get the hang of it!

# Hi there! I could have sworn I've been to this blog before but after checking through some of the post I realized it's new to me. Nonetheless, I'm definitely glad I found it and I'll be bookmarking and checking back often! 2022/08/10 8:43 Hi there! I could have sworn I've been to this blo

Hi there! I could have sworn I've been to this blog before but after checking
through some of the post I realized it's new to me.

Nonetheless, I'm definitely glad I found it and I'll be bookmarking and checking back
often!

# Its not my first time to go to see this web page, i am visiting this web site dailly and take good information from here all the time. 2022/08/12 6:11 Its not my first time to go to see this web page,

Its not my first time to go to see this web page,
i am visiting this web site dailly and take good information from here all the time.

# I read this piece of writing fully about the resemblance of hottest and previous technologies, it's amazing article. 2022/08/13 0:45 I read this piece of writing fully about the resem

I read this piece of writing fully about the resemblance of hottest
and previous technologies, it's amazing article.

# of course like your website but you have to test the spelling on quite a few of your posts. A number of them are rife with spelling problems and I to find it very bothersome to inform the reality on the other hand I will surely come again again. 2022/08/14 13:59 of course like your website but you have to test t

of course like your website but you have to test the spelling on quite a few
of your posts. A number of them are rife with spelling problems and I to find it very bothersome to inform the reality on the
other hand I will surely come again again.

# of course like your website but you have to test the spelling on quite a few of your posts. A number of them are rife with spelling problems and I to find it very bothersome to inform the reality on the other hand I will surely come again again. 2022/08/14 14:00 of course like your website but you have to test t

of course like your website but you have to test the spelling on quite a few
of your posts. A number of them are rife with spelling problems and I to find it very bothersome to inform the reality on the
other hand I will surely come again again.

# of course like your website but you have to test the spelling on quite a few of your posts. A number of them are rife with spelling problems and I to find it very bothersome to inform the reality on the other hand I will surely come again again. 2022/08/14 14:02 of course like your website but you have to test t

of course like your website but you have to test the spelling on quite a few
of your posts. A number of them are rife with spelling problems and I to find it very bothersome to inform the reality on the
other hand I will surely come again again.

# of course like your website but you have to test the spelling on quite a few of your posts. A number of them are rife with spelling problems and I to find it very bothersome to inform the reality on the other hand I will surely come again again. 2022/08/14 14:03 of course like your website but you have to test t

of course like your website but you have to test the spelling on quite a few
of your posts. A number of them are rife with spelling problems and I to find it very bothersome to inform the reality on the
other hand I will surely come again again.

# Thanks for every other informative website. The place else may just I get that kind of information written in such a perfect approach? I've a venture that I'm just now operating on, and I've been at the look out for such information. 2022/08/15 9:40 Thanks for every other informative website. The p

Thanks for every other informative website. The place else may just I get that kind of information written in such a perfect approach?
I've a venture that I'm just now operating on, and I've been at the look out for such information.

# Hey there! I know this is kind of off topic but I was wondering if you knew where I could get a captcha plugin for my comment form? I'm using the same blog platform as yours and I'm having trouble finding one? Thanks a lot! 2022/08/19 11:48 Hey there! I know this is kind of off topic but I

Hey there! I know this is kind of off topic but
I was wondering if you knew where I could get a captcha plugin for my comment form?
I'm using the same blog platform as yours and I'm having trouble finding one?
Thanks a lot!

# I take pleasure in, lead to I discovered exactly what I was having a look for. You have ended my 4 day lengthy hunt! God Bless you man. Have a great day. Bye 2022/09/08 17:36 I take pleasure in, lead to I discovered exactly w

I take pleasure in, lead to I discovered exactly what I was having a
look for. You have ended my 4 day lengthy hunt!
God Bless you man. Have a great day. Bye

# I take pleasure in, lead to I discovered exactly what I was having a look for. You have ended my 4 day lengthy hunt! God Bless you man. Have a great day. Bye 2022/09/08 17:37 I take pleasure in, lead to I discovered exactly w

I take pleasure in, lead to I discovered exactly what I was having a
look for. You have ended my 4 day lengthy hunt!
God Bless you man. Have a great day. Bye

# I take pleasure in, lead to I discovered exactly what I was having a look for. You have ended my 4 day lengthy hunt! God Bless you man. Have a great day. Bye 2022/09/08 17:38 I take pleasure in, lead to I discovered exactly w

I take pleasure in, lead to I discovered exactly what I was having a
look for. You have ended my 4 day lengthy hunt!
God Bless you man. Have a great day. Bye

# I take pleasure in, lead to I discovered exactly what I was having a look for. You have ended my 4 day lengthy hunt! God Bless you man. Have a great day. Bye 2022/09/08 17:39 I take pleasure in, lead to I discovered exactly w

I take pleasure in, lead to I discovered exactly what I was having a
look for. You have ended my 4 day lengthy hunt!
God Bless you man. Have a great day. Bye

タイトル
名前
URL
コメント