免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
1234
最近访问板块 发新帖
楼主: emacsnw
打印 上一主题 下一主题

[算法] 刚看到的一个排序算法题,大家讨论讨论。 [复制链接]

论坛徽章:
0
31 [报告]
发表于 2007-01-01 17:14 |只看该作者
其实大家讨论时都没有利用题目给出的条件,就是有序的数列,所以一切的空间问题讨论都没有意义。下面给出我的算法,欢迎大家指正:
#include <stdio.h>
int m[9]={1,1,1,2,3,3,4,5,5};
void unique(int s[], int n)
{
        int i,j,k,tmp;
        for(i=0;i<n;i++)
        {
                for(j=i+1;j<n;j++)
                {
                        if(s[i]>=s[j])
                                continue;
                        break;
                }
                if(j<n)
                {
                        tmp=s[j];
                        for(k=j;k>i+1;k--)
                                s[k]=s[k-1];
                        s[k]=tmp;
                }
        }
}

main()
{
        int i;
        for(i=0;i<9;i++)
                printf("%d ",m[i]);
        printf("\n");
        unique(m,9);
        for(i=0;i<9;i++)
                printf("%d ",m[i]);
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP