用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字
云代码 - c代码库

三色旗问题

2012-10-30 作者: 程序猿style举报

[c]代码库

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
 
#define BLUE 'b'
#define WHITE 'w'
#define RED 'r'
 
SWAP ( int x,int y );
 
char color[]={'r','w','b','w','w',
              'b','r','b','w','r','\0'
             };
 
/*
三色旗问题
假设有一条绳子,上面有红、白、蓝三种颜色的旗子,起初绳子上的旗子颜色并没有顺序,您希望将之分类,并排列为蓝、白、红的顺序,要如何移动次数才会最少,注意您只能在绳子上进行这个动作,而且一次只能调换两个旗子
*/
 
int main()
{
 
 
    int wFlag=0;
    int bFlag=0;
    int rFlag=strlen ( color )-1;
    int i;
 
    for ( i=0; i<strlen ( color ); i++ )
        printf ( "%c",color[i] );
    printf ( "\n" );
 
    while ( wFlag<=rFlag )
    {
        if ( color[wFlag]==WHITE )
            wFlag++;
        else if ( color[wFlag]==BLUE )
        {
            SWAP ( bFlag,wFlag );
            bFlag++;
            wFlag++;
        }
        else
        {
            while ( wFlag<rFlag&&color[rFlag]==RED )
                rFlag--;
            SWAP ( rFlag,wFlag );
            rFlag--;
        }
    }
 
    for ( i=0; i<strlen ( color ); i++ )
        printf ( "%c",color[i] );
    printf ( "\n" );
 
    return 0;
}
 
SWAP ( int x,int y )
{
    char temp;
    temp=color[x];
    color[x]=color[y];
    color[y]=temp;
}

[代码运行效果截图]


三色旗问题


网友评论    (发表评论)


发表评论:

评论须知:

  • 1、评论每次加2分,每天上限为30;
  • 2、请文明用语,共同创建干净的技术交流环境;
  • 3、若被发现提交非法信息,评论将会被删除,并且给予扣分处理,严重者给予封号处理;
  • 4、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。


扫码下载

加载中,请稍后...

输入口令后可复制整站源码

加载中,请稍后...