2.1.3 Sorting a Three-Valued Sequence 三值的排序
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 三值的排序相关推荐
- Sorting a Three-Valued Sequence 三值的排序
Sorting a Three-Valued Sequence 三值的排序 Time Limit: 1 Sec Memory Limit: 64 MB Description 排序是一种很频繁的计算 ...
- usaco Sorting a Three-Valued Sequence 三值的排序
一开始想贪心,但是一想这是搜索章节应该用bfs?(为什么这么想看我上一个usaco的题目),,,,,,,,,,结果我贪心做出来了.然后我百度一下了别人做的好像么没人用bfs我不知道可不可以做出来. 思 ...
- [P1459 [USACO2.1]三值的排序 Sorting a Three-Valued Sequence]
P1459 [USACO2.1]三值的排序 Sorting a Three-Valued Sequence 解题思路:贪心.对b数组排序,先找如果交换一次就可以让两组都相等的交换一下,再找交换一次,可 ...
- 三值的排序 Sorting a Three-Valued Sequence(洛谷 P1459)
三值的排序 Sorting a Three-Valued Sequence 题目描述 排序是一种很频繁的计算任务.现在考虑最多只有三值的排序问题.一个实际的例子是,当我们给某项竞赛的优胜者按金银铜牌排 ...
- 三值的排序 Sorting a Three-Valued Sequence
题目描述 排序是一种很频繁的计算任务.现在考虑最多只有三值的排序问题.一个实际的例子是,当我们给某项竞赛的优胜者按金银铜牌排序的时候.在这个任务中可能的值只有三种1,2和3.我们用交换的方法把他排成升 ...
- P1459 三值的排序 Sorting a Three-Valued
题目描述 排序是一种很频繁的计算任务.现在考虑最多只有三值的排序问题.一个实际的例子是,当我们给某项竞赛的优胜者按金银铜牌排序的时候.在这个任务中可能的值只有三种1,2和3.我们用交换的方法把他排成升 ...
- 华山论剑之 PostgreSQL sequence (三)
sequence cache 从上面可以看到,sequence 默认的 cache 是1. 在高并发的系统中,为了提高性能,可以增大 cache,如 10,即一次将 sequence 的10个数值 l ...
- oracle如何查看sequence的值,Oracle sequence详解
创建sequence: create sequence seq_test increment by 1 start with 1 noMaxValue noCycle cache 10; create ...
- Oracle修改SEQUENCE起始值
查看当前表的最大序列值 SELECT MAX(T.L_INPUT_NO) FROM table t; 操作:例如:修改序列名称为SeqCheckInputNo的序列号 select SeqCheckI ...
- Oracle修改序列(sequence)当前值的两种方法
1.直接drop sequence seq_t_test;然后重新创建并且设置序列的初始值为希望的数据 SQL: drop sequence seq_t_test; create sequence s ...
最新文章
- Python的隐藏功能
- GridView中使用DataFromatString
- WebApi中跨域解决办法
- Python的序列化与反序列化
- Extending_and_embedding_php翻译
- java匿名内部类runnable_Java内部类:匿名内部类(四)
- ffmpeg 无法找到libpostproc的问题
- android应用程序列表,List列表应用程序-小知识 #103
- 电子工业出版社博文视点在2010年系统架构师大会上集锦
- centos,apache运维经验
- 你对云存储的安全性了解多少?
- webserver技术总结之一:webserver概念
- 零基础搭建量化交易框架
- X-Scan 端口扫描工具下载和使用教程
- tcflush()用法 以及 Termios 介绍
- qt编译出错 /usr/bin/ld 找不到 -lGL cannot find -lGL
- python遇到Segmentation fault (core dumped)调试方法
- 正月十五闹元宵,平安吉祥乐团圆
- LPC1768 PWM1输出PWM示例
- win10如何修改mac地址(亲测通过)