博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
USACO--2.1Sorting a Three-Valued Sequence
阅读量:2227 次
发布时间:2019-05-09

本文共 1898 字,大约阅读时间需要 6 分钟。

我们可以知道最后排序以后的结果,也就是所有的1,2,3所处的位置;

所以我们可以预先统计1,2,3的数量,然后对于处在1位置的2,3我们先分别到他们各自应该处在的位置,寻找是否有1然后交换,如果没有再到别的位置寻找;处理完1后,我们再统计一下应该是2的位置上有多少3,就可以得到答案了。

代码如下:

/*ID: 15674811LANG: C++TASK: sort3*/#include
#include
#include
#include
using namespace std;void swp(int &a,int &b){ int t=a; a=b; b=t;}int main(){ ofstream fout("sort3.out"); ifstream fin("sort3.in"); ///ifstream fin("lkl.txt"); int n; while(fin>>n) { int a[1010],num[4]; memset(num,0,sizeof(num)); for(int i=1;i<=n;i++) { fin>>a[i]; num[a[i]]++; } int cnt=0; for(int i=1;i<=num[1];i++) { if(a[i]==2) { cnt++; int j; for(j=num[1]+1;j<=num[1]+num[2];j++) if(a[j]==1) { swp(a[i],a[j]); break; } if(j>num[1]+num[2]) for(int d=num[1]+num[2]+1;d<=n;d++) if(a[d]==1) { swp(a[i],a[d]); break; } } if(a[i]==3) { cnt++; int j; for(j=num[1]+num[2]+1;j<=n;j++) if(a[j]==1) { swp(a[i],a[j]); break; } if(j>n) for(int d=num[1]+1;d<=num[1]+num[2];d++) if(a[d]==1) { swp(a[d],a[i]); break; } } } for(int i=num[1]+1;i<=num[1]+num[2];i++) { if(a[i]!=2) cnt++; } fout<
<

转载地址:http://okrfb.baihongyu.com/

你可能感兴趣的文章
Eclipse使用(十一)—— 使用Eclipse创建简单的Maven JavaWeb项目
查看>>
Intellij IDEA使用(十三)—— 在Intellij IDEA中配置Maven
查看>>
面试题 —— 关于main方法的十个面试题
查看>>
集成测试(一)—— 使用PHP页面请求Spring项目的Java接口数据
查看>>
使用Maven构建的简单的单模块SSM项目
查看>>
Intellij IDEA使用(十四)—— 在IDEA中创建包(package)的问题
查看>>
FastDFS集群架构配置搭建(转载)
查看>>
HTM+CSS实现立方体图片旋转展示效果
查看>>
FFmpeg 命令操作音视频
查看>>
问题:Opencv(3.1.0/3.4)找不到 /opencv2/gpu/gpu.hpp 问题
查看>>
目的:使用CUDA环境变量CUDA_VISIBLE_DEVICES来限定CUDA程序所能使用的GPU设备
查看>>
问题:Mysql中字段类型为text的值, java使用selectByExample查询为null
查看>>
程序员--学习之路--技巧
查看>>
解决问题之 MySQL慢查询日志设置
查看>>
contOS6 部署 lnmp、FTP、composer、ThinkPHP5、docker详细步骤
查看>>
TP5.1模板布局中遇到的坑,配置完不生效解决办法
查看>>
PHPstudy中遇到的坑No input file specified,以及传到linux环境下遇到的坑,模板文件不存在
查看>>
TP5.1事务操作和TP5事务回滚操作多表
查看>>
composer install或composer update 或 composer require phpoffice/phpexcel 失败解决办法
查看>>
TP5.1项目从windows的Apache服务迁移到linux的Nginx服务需要注意几点。
查看>>