Description

排序是一种很频繁的计算任务。现在考虑最多只有三值的排序问题。一个实际的例子是,当我们给某项竞赛的优胜者按金银铜牌序的时候。 在这个任务中可能的值只有三种1,2和3。我们用交换的方法把他排成升序的。 写一个程序计算出,给定的一个1,2,3组成的数字序列,排成升序所需的最少交换次数。

Input

Line 1: N (1 <= N <= 1000) Lines 2-N+1: 每行一个数字,共N行。(1..3)

Output

共一行,一个数字。表示排成升序所需的最少交换次数。

Sample Input

9
2
2
1
3
3
3
2
3
1

Sample Output

4

思路:我们先考虑统计数字1 ,2  ,3  的个数和,然后我们在首先考虑1的区间内有多少非1 的个数,然后统计2~3区间内3的个数,在统计3~n区间内2的个数,然后我们可以考虑的是非1的个数肯定要去交换位置,后面的话就可以等价替换掉,然后我们就可以考虑计算后两个区间内的最大值,然后相加得出。

#include <iostream>
#include <algorithm>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <cmath>
#include <string>
#include <queue>
#include <stack>
#include <map>
#include <set>
typedef long long LL;
const long long INF = 0x3f3f3f3f;
const long long mod = 1e9+7;
const double PI = acos(-1.0);
const int maxx = 800;
#define MAX 10010
using namespace std;
int x[1100],y[1100],num1,num2,num3;
int main()
{int n;cin>>n;for(int i=0;i<n;i++){cin>>x[i];if(x[i]==1)num1++;if(x[i]==2)num2++;if(x[i]==3)num3++;}for(int i=0;i<num1;i++)if(x[i]!=1)y[1]++;for(int i=num1;i<num1+num2;i++)if(x[i]==3)y[2]++;for(int i=num1+num2;i<n;i++)if(x[i]==2)y[3]++;cout<<y[3]+max(y[1],y[2])<<endl;return 0;
}

2.1.3 Sorting a Three-Valued Sequence 三值的排序相关推荐

  1. Sorting a Three-Valued Sequence 三值的排序

    Sorting a Three-Valued Sequence 三值的排序 Time Limit: 1 Sec  Memory Limit: 64 MB Description 排序是一种很频繁的计算 ...

  2. usaco Sorting a Three-Valued Sequence 三值的排序

    一开始想贪心,但是一想这是搜索章节应该用bfs?(为什么这么想看我上一个usaco的题目),,,,,,,,,,结果我贪心做出来了.然后我百度一下了别人做的好像么没人用bfs我不知道可不可以做出来. 思 ...

  3. [P1459 [USACO2.1]三值的排序 Sorting a Three-Valued Sequence]

    P1459 [USACO2.1]三值的排序 Sorting a Three-Valued Sequence 解题思路:贪心.对b数组排序,先找如果交换一次就可以让两组都相等的交换一下,再找交换一次,可 ...

  4. 三值的排序 Sorting a Three-Valued Sequence(洛谷 P1459)

    三值的排序 Sorting a Three-Valued Sequence 题目描述 排序是一种很频繁的计算任务.现在考虑最多只有三值的排序问题.一个实际的例子是,当我们给某项竞赛的优胜者按金银铜牌排 ...

  5. 三值的排序 Sorting a Three-Valued Sequence

    题目描述 排序是一种很频繁的计算任务.现在考虑最多只有三值的排序问题.一个实际的例子是,当我们给某项竞赛的优胜者按金银铜牌排序的时候.在这个任务中可能的值只有三种1,2和3.我们用交换的方法把他排成升 ...

  6. P1459 三值的排序 Sorting a Three-Valued

    题目描述 排序是一种很频繁的计算任务.现在考虑最多只有三值的排序问题.一个实际的例子是,当我们给某项竞赛的优胜者按金银铜牌排序的时候.在这个任务中可能的值只有三种1,2和3.我们用交换的方法把他排成升 ...

  7. 华山论剑之 PostgreSQL sequence (三)

    sequence cache 从上面可以看到,sequence 默认的 cache 是1. 在高并发的系统中,为了提高性能,可以增大 cache,如 10,即一次将 sequence 的10个数值 l ...

  8. oracle如何查看sequence的值,Oracle sequence详解

    创建sequence: create sequence seq_test increment by 1 start with 1 noMaxValue noCycle cache 10; create ...

  9. Oracle修改SEQUENCE起始值

    查看当前表的最大序列值 SELECT MAX(T.L_INPUT_NO) FROM table t; 操作:例如:修改序列名称为SeqCheckInputNo的序列号 select SeqCheckI ...

  10. Oracle修改序列(sequence)当前值的两种方法

    1.直接drop sequence seq_t_test;然后重新创建并且设置序列的初始值为希望的数据 SQL: drop sequence seq_t_test; create sequence s ...

最新文章

  1. Python的隐藏功能
  2. GridView中使用DataFromatString
  3. WebApi中跨域解决办法
  4. Python的序列化与反序列化
  5. Extending_and_embedding_php翻译
  6. java匿名内部类runnable_Java内部类:匿名内部类(四)
  7. ffmpeg 无法找到libpostproc的问题
  8. android应用程序列表,List列表应用程序-小知识 #103
  9. 电子工业出版社博文视点在2010年系统架构师大会上集锦
  10. centos,apache运维经验
  11. 你对云存储的安全性了解多少?
  12. webserver技术总结之一:webserver概念
  13. 零基础搭建量化交易框架
  14. X-Scan 端口扫描工具下载和使用教程
  15. tcflush()用法 以及 Termios 介绍
  16. qt编译出错 /usr/bin/ld 找不到 -lGL cannot find -lGL
  17. python遇到Segmentation fault (core dumped)调试方法
  18. 正月十五闹元宵,平安吉祥乐团圆
  19. LPC1768 PWM1输出PWM示例
  20. win10如何修改mac地址(亲测通过)

热门文章

  1. 【Storm总结-6】Twitter Storm: DRPC简介
  2. Nginx服务器中的Socket切分,需要的朋友可以参考下
  3. 携手英特尔,百度开放云将提供更强悍云服务
  4. JavaScript 常用功能总结
  5. [jquery] 图片热区随图片大小自由缩放
  6. Shader预处理宏、内置状态变量、多版本编译等
  7. mysql exist和in的区别
  8. 用new/delete动态创建数组| 一维/二维/三维
  9. 防盗链Nginx设置图片防盗链,设置无效的请仔细看红字
  10. Android:Fragment官方文档