问题描述
试题编号: 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. Netty对WebSocket的支持(五)

    Netty对WebSocket的支持(五) 一.WebSocket简介 在Http1.0和Http1.1协议中,我们要实现服务端主动的发送消息到网页或者APP上,是比较困难的,尤其是现在IM(即时通信 ...

  2. value toDF is not a member of org.apache.spark.rdd.RDD

    idea显示toDF() 没有这个函数,显示错误: Error:(82, 8) value toDF is not a member of org.apache.spark.rdd.RDD[com.d ...

  3. 编码(ACSII unicod UTF-8)、QT输出中文乱码深入分析

    总结: 1. qt输出中文乱码原因分析 qt的编程环境默认是utf-8编码格式(关于编码见下文知识要点一): cout << "中文" << endl; 程 ...

  4. Java学习笔记2(输入与随机数简单介绍)

    输入: import java.util.Scanner; public class ScannerDemo{ public static void main(String[ ] args){ Sca ...

  5. 多个JDK使用批处理命令切换JDK版本

    本篇博客参考的链接 http://blog.csdn.net/hu199055/article/details/70145389 https://www.cnblogs.com/xdp-gacl/p/ ...

  6. ECharts模拟迁徙案例

    ECharts模拟迁徙案例 独立页面:http://211.140.7.173:8081/t/wuhairui/ditu/a.html

  7. V4l2的结构体 --- ioctl【转】

      在应用程序获取视频数据的流程中,都是通过 ioctl 命令与驱动程序进行交互,常见的 ioctl 命令有: VIDIOC_QUERYCAP /* 获取设备支持的操作 */ VIDIOC_G_FMT ...

  8. 副本机制与副本同步------《Designing Data-Intensive Applications》读书笔记6

    进入到第五章了,来到了分布式系统之中最核心与复杂的内容:副本与一致性.通常分布式系统会通过网络连接的多台机器上保存相同数据的副本,所以在本篇之中,我们来展开看看如何去管理和维护这些副本,以及这个过程之 ...

  9. Django---->模板层(template)

    模板层(template) 你可能已经注意到我们在例子视图中返回文本的方式有点特别. 也就是说,HTML被直接硬编码在 Python代码之中. 1 2 3 4 def current_datetime ...

  10. Django的生命周期图解

    下边的图就是一次完整的django生命周期,从客户端输入url,经过wsgi模块处理,得到符合HTTP协议的字符串,走中间件,假如中间件return None,继续往下走到urls......; 假如 ...