问题描述
试题编号: 201503-2
试题名称: 数字排序
时间限制: 1.0s
内存限制: 256.0MB
问题描述:

问题描述
  给定n个整数,请统计出每个整数出现的次数,按出现次数从多到少的顺序输出。
输入格式
  输入的第一行包含一个整数n,表示给定数字的个数。
  第二行包含n个整数,相邻的整数之间用一个空格分隔,表示所给定的整数。
输出格式
  输出多行,每行包含两个整数,分别表示一个给定的整数和它出现的次数。按出现次数递减的顺序输出。如果两个整数出现的次数一样多,则先输出值较小的,然后输出值较大的。
样例输入
12
5 2 3 3 1 3 4 2 5 2 3 5
样例输出
3 4
2 3
5 3
1 1
4 1
评测用例规模与约定
  1 ≤ n ≤ 1000,给出的数都是不超过1000的非负整数。
 
 
解题思路:
 
实现代码(c++):
  

 #include <utility>
#include <iostream>
#include <map>
#include <iterator>
#include <functional> using namespace std; int main(){
map<int,int> j;
multimap<int,int,greater<int> > jj;
int n;
cin>>n;
for(int i=;i<n;i++)
{
int a;
cin>>a;
j[a]++;
}
for(map<int,int>::iterator it = j.begin();it!=j.end();it++)
{
jj.insert(pair<int,int>(it->second,it->first));
}
for(map<int,int>::iterator it = jj.begin();it!=jj.end();it++)
{
cout<<it->second<<" "<<it->first<<endl;
}
return ;
}

运行结果:

  

实现代码(java):

  

 import java.util.Arrays;
import java.util.Scanner; public class NumberPaixu {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int arr[] = new int[n + ];
display(sort_2(type_arr(input1(arr, sc))));
} public static int[] input1(int arr[], Scanner sc) {
int len = arr.length;
for (int i = ; i < len - ; i++) {
arr[i] = sc.nextInt();
}
arr[len - ] = ;
return arr;
} public static int[][] type_arr(int arr[]) {
Arrays.sort(arr);
int len = arr.length;
int arr_2[][] = new int[len][];
for (int i = ; i < arr_2.length; i++) {
for (int j = ; j < ; j++) {
arr_2[i][j] = -;
}
}
int temp = ;
int k = ;
int arr_2_index = ;
for (int i = ; i < len; i++) {
if (arr[i] == arr[k]) {
temp++;
if (i != len - )
continue;
}
arr_2[arr_2_index][] = arr[k];
arr_2[arr_2_index][] = temp;
arr_2_index++;
temp = ;
k = i;
if (i != len - )
i--;
}
return arr_2;
} public static int[][] sort_2(int arr_2[][]) {
int len = arr_2.length;
for (int i = ; i < len; i++) {
for (int j = ; j < len - i - ; j++) {
if ((arr_2[j][] < arr_2[j + ][])
|| (arr_2[j][] == arr_2[j + ][] && arr_2[j][] > arr_2[j + ][])) {
int temp = arr_2[j][];
arr_2[j][] = arr_2[j + ][];
arr_2[j + ][] = temp;
temp = arr_2[j][];
arr_2[j][] = arr_2[j + ][];
arr_2[j + ][] = temp;
}
}
}
return arr_2;
} public static void display(int arr_2[][]) {
int len = arr_2.length;
for (int i = ; i < len; i++) {
if (arr_2[i][] != -) {
System.out.println(arr_2[i][] + " " + arr_2[i][]);
}
}
}
}

运行结果:

我的实现代码(java):

 package ccf_test2015_03;

 import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Scanner; public class NumberPaixu2 { private static int N ; public static void main(String[] args) { Map map = new HashMap(); Scanner input = new Scanner(System.in); N = input.nextInt(); int[][] number = new int[N][2]; for(int i = 0; i < N; i++){ int key = input.nextInt(); if(map.get(key) != null){ int value = (int) map.get(key); map.replace(key, value, ++value); }else{ map.put(key, 1);
}
}
int count = 0; Iterator entries = map.entrySet().iterator(); while(entries.hasNext()){ Map.Entry entry = (Map.Entry) entries.next(); int key = (int) entry.getKey(); int value = (int) entry.getValue(); number[count][0] = key; number[count++][1] = value;
}
for(int i = 0; i < count-1; i++){ for(int j = 0 ;j < count - i - 1; j++){ if(number[j][1] < number[j + 1][1]){ int[] temp = number[j]; number[j] = number[j + 1]; number[j + 1] = temp; }else if(number[j][1] == number[j + 1][1]){ if(number[j][0] > number[j + 1][0]){ int[] temp = number[j]; number[j] = number[j + 1]; number[j + 1] = temp;
}
}
}
} for(int i = 0; i < count; i++){ System.out.println(number[i][0] + "\t" + number[i][1]);
} } }

运行结果:

CCF系列之数字排序(201503-2)的更多相关文章

  1. CCF CSP 201503-2 数字排序

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201503-2 数字排序 问题描述 给定n个整数,请统计出每个整数出现的次数,按出现次数从多到 ...

  2. CCF CSP 201503-2 数字排序 (map+自定义排序)

    题目链接:http://118.190.20.162/view.page?gpid=T26 返回试题列表 问题描述 试题编号: 201503-2 试题名称: 数字排序 时间限制: 1.0s 内存限制: ...

  3. 基于Hadoop 2.6.0运行数字排序的计算

    上个博客写了Hadoop2.6.0的环境部署,下面写一个简单的基于数字排序的小程序,真正实现分布式的计算,原理就是对多个文件中的数字进行排序,每个文件中每个数字占一行,排序原理是按行读取后分块进行排序 ...

  4. SQL SERVER 字符串按数字排序

    需求是这样的: 数据库表里面有一个字段类型是nvachar,存的值是数字和字符混合的,要实现先按数字排序,再按字母倒序. 思路: 考虑这个字段的值是否是有规律可循的,把要按数字排序的部分转换为数字,再 ...

  5. JavaScript按纯数字排序

      直接上代码: var arr=[ {name:"张散步",age:"23",sports:"篮球",number:"23112 ...

  6. php冒泡排序实现方法,传入几个数字排序后 输出实战例子

    php冒泡排序实现方法,传入几个数字排序后 输出实战例子 算法和数据结构是一个编程工作人员的内功.四种入门级排序算法: 冒泡排序.选择排序.插入排序.快速排序. 一.冒泡排序 原理:对一组数据,比较相 ...

  7. mysql将字符串字段转为数字排序或比大小

    SELECT * FROM Student WHERE 1 = 1 ORDER BY -ID DESC ; SELECT * FROM Student WHERE 1 = 1 ORDER BY (ID ...

  8. sort()函数到底是怎样进行数字排序的

    很多人会用sort(),并不见得知道它具体是怎样给数字排序的.其实不知道也行,会用就可以,感兴趣的可以来看看. var numberArray = [2,4,1,3]; numberArray.sor ...

  9. CCF201503-2 数字排序 java(100分)

    试题编号: 201503-2 试题名称: 数字排序 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 给定n个整数,请统计出每个整数出现的次数,按出现次数从多到少的顺序输出. 输 ...

随机推荐

  1. angular4.0快速import依赖路径

    快捷键:ALT + ENTER 直接import对应的依赖路径

  2. [UWP]如何使用Fluent Design System (上)

    1. 前言 微软在Build 2017中公布了新的设计语言Fluent Design System(以下简称FDS),不过官网只是堆砌了各种华丽的词语以及一堆动画.至于在UWP中要做成怎么样,怎么做, ...

  3. sqoop数据迁移(基于Hadoop和关系数据库服务器之间传送数据)

    1:sqoop的概述: (1):sqoop是apache旗下一款“Hadoop和关系数据库服务器之间传送数据”的工具.(2):导入数据:MySQL,Oracle导入数据到Hadoop的HDFS.HIV ...

  4. 【LCT】BZOJ2049 [SDOI2008]Cave 洞穴勘测

    2049: [Sdoi2008]Cave 洞穴勘测 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 10059  Solved: 4863[Submit ...

  5. vue 设计日历表

    日历的功能,我们会经常用到,且逻辑比较复杂,小算法较多,花了半天时间写了个,特此详记. 先贴图 功能阐述:返回本月不多说,设置工作日和节假日是为了公司制度需要,后台会有假日表来记录. 为了适应于vue ...

  6. [转]Django时间查询

    1.gt:大于某个时间 now = datetime.datetime.now() 前一天 start = now – datetime.timedelta(hours=23, minutes=59, ...

  7. git删除本地分支

    远端master分支有更新需要拉取至本地,但是代码有些地方做了修改导致了小冲突,但是这些修改又是无关紧要的,于是就打算直接删除掉本地分支再重新拉取master分支,过程如下: //查看本地分支 git ...

  8. Python源码剖析之准备工作

    一个Python程序开发者, 也是C语言爱好者, 为了加强自己对Python语言实现的理解, 最近选择阅读下陈儒老师的书, 对Python3.5.1源码进行阅读, 再次记录下读书笔记.  一.Pyth ...

  9. 使用socket搭建一个网络聊天室

    #服务器端import socket import threading #创建一个TCP端 sock = socket.socket(socket.AF_INET, socket.SOCK_STREA ...

  10. CTFCrackTools在Windows下显示A Java Exception has occurred的解决方案

    打CTF做密码学的人一定少不了用这个工具,CTFCrackTools,这个几乎可以号称密码学的神器,但是呢,最近博主遇到了一些麻烦事,每次打开的时候都是显示A Java Exception has o ...