当前位置: 首页 > news >正文

专业网站建设推荐网站结构分析怎么做

专业网站建设推荐,网站结构分析怎么做,网站seo专员招聘,怎么做游戏自动充值的网站【题目】 病人登记看病#xff0c;编写一个程序#xff0c;将登记的病人按照以下原则排出看病的先后顺序#xff1a; 老年人#xff08;年龄 60岁#xff09;比非老年人优先看病。 老年人按年龄从大到小的顺序看病#xff0c;年龄相同的按登记的先后顺序排序。 非…【题目】 病人登记看病编写一个程序将登记的病人按照以下原则排出看病的先后顺序 老年人年龄 60岁比非老年人优先看病。 老年人按年龄从大到小的顺序看病年龄相同的按登记的先后顺序排序。 非老年人按登记的先后顺序看病。 【输入格式】 第1行输入一个小于100的正整数表示病人的个数 后面按照病人登记的先后顺序每行输入一个病人的信息包括一个长度小于10的字符串表示病人的ID每个病人的ID各不相同且只包含数字和字母一个整数表示病人的年龄中间用单个空格隔开。 【输出格式】 按排好的看病顺序输出病人的ID每行一个。 【样例】 样例输入 5 021075 40 004003 15 010158 67 021033 75 102012 30 样例输出 021033 010158 021075 004003 102012 【思路】 1. 先把输入的数据按照年龄分成两个 LinkedHashMap一个是年龄大于等于 60岁 的老年人 一个是非老年人 2. 对老年人的 LinkedHashMap按照 年龄大小 进行从大到小排序 3. 非老年人的 LinkedHashMap就按照登记顺序即在数组中的顺序输出就可以。 【注意】这里需要考虑到排序的 稳定性问题 排序算法的稳定性是指当存在两个相等的元素时排序后它们的相对位置是否保持不变。 具体来说如果在排序前有两个相等的元素 A 和 B且 A 出现在 B 的前面那么如果排序算法是稳定的经过排序后A 仍然应该出现在 B 的前面。 稳定性对于某些应用场景非常重要。例如在按照 老年人的年龄 进行排序的情况下如果有两个 年龄相同 的老人他们的顺序可能会影响到他们的排名。如果排序算法是稳定的相同年龄的老人的 相对顺序 将被保留而这个相对顺序恰好就是 登记的先后顺序。 【注意】观察题目的输入 Main函数里面的public static String[] sort(String[] id, int[] age){ return id; } 这个函数的输入是 String[] id 和 int[] age的也就是说题目已经帮我们把 输入的 5 021075 40 004003 15 010158 67 021033 75 102012 30 转换成了分离的 021075 004003 010158 021033 102012 和 40 15 67 75 30 所以我们要建立一下 String[] id 和 int[] age 的映射关系由于可能会存在老年人年龄相同的情况Key值相同所以不用二叉搜索树而是用 Hashmap 。 【排序算法】 基本的冒泡算法就可以 【踩坑】 所以要用 MapString,Integer map new LinkedHashMap(); 另外由于年龄可能存在相同的情况所以如果把 age 作为 Map 的 Key 值会存在相同 Key 值的被覆盖的问题比如说 有 011111 44, 022222 44 后面的022222 44 就会把前面的覆盖掉因为 Key 值只可能是唯一对应的。 【代码】 import java.util.*;public class test {public static String[] coupons(String[] id, int[] age) { // 错误写法 HashMapInteger, String map new HashMap();// 建立一个有序的LinkedHashMap存放所有数据MapString,Integer map new LinkedHashMap();for (int i 0; i age.length; i) {map.put(id[i],age[i]);}System.out.println(map);// 把数据分成 老年人 map 和 非老年人 mapMapString,Integer oldMap new LinkedHashMap();MapString,Integer youngMap new LinkedHashMap();for (String key : map.keySet()) {int value map.get(key);if (value 60) {oldMap.put(key, value);} else {youngMap.put(key, value);}}// 用List把他们包裹起来ListMap.EntryString,Integer sortedOldList new ArrayList(oldMap.entrySet());ListMap.EntryString,Integer youngList new ArrayList(youngMap.entrySet());System.out.println(youngList);// 对老年人进行按照年龄大小的冒泡排序for (int i 0; i sortedOldList.size(); i) {for (int j 0; j sortedOldList.size() - 1 - i; j) {if (sortedOldList.get(j).getValue() sortedOldList.get(j 1).getValue()) {Collections.swap(sortedOldList, j, j 1);}}}// 输出for (int i 0; i sortedOldList.size(); i) {id[i] sortedOldList.get(i).getKey();}for (int i sortedOldList.size(); i (sortedOldList.size() youngList.size()); i) {id[i] youngList.get(i - sortedOldList.size()).getKey();}return id;}// APPEND BEGINpublic static void main(String[] args){Scanner reader new Scanner(System.in);int n reader.nextInt();String[] id new String[n];int[] age new int[n];int i 0;while (reader.hasNext()){id[i] reader.next();age[i] reader.nextInt();if (i age.length) break;}String[] result coupons(id,age);for (String re : result){System.out.println(re);}} }
http://www.huolong8.cn/news/138388/

相关文章:

  • 织梦网站404怎么做视频网站设计与开发
  • seo网站推广怎么做网站出现的的问题
  • 教育培训推广网站模板ps工具设计网站
  • 门户网站开发是什么外贸营销网站建站
  • 地方信息网站源码怎么查网站是用什么语言做的
  • 门户网站要求黑白灰 网站
  • 网站建设 牛商网技术提供泰安做网站建设的公司
  • 仿中国化妆品网站模板站长之家网址ip查询
  • 购物网站域名大小邓州微网站建设
  • 简述建站流程黄冈市网站建设
  • 小学英语教师做应用相关网站网站项目策划大纲
  • 重庆建设门户网站戴尔网站建设
  • 网站备案通过建设工程施工合同示范文本2017版
  • 长沙网站seo推广公司高端定制网站建设公司
  • 郑州淘宝网站建设福田蒙派克6座上蓝牌京牌
  • 多种不同产品的网站怎么做seowordpress建站模板下载
  • 网站空间名北京做网站ezhixi
  • 各网站推广灵璧做网站公司
  • 网站开发主页乡镇网站建设工作计划
  • 清苑住房和城乡建设局网站北京房产网站建设
  • 百度seo 站长工具网站站外引流怎么做
  • 电影网站建设策划人网
  • 南昌公司网站开发济南网站建设q.479185700惠
  • app开发需要哪些技术网站优化方案
  • 网站建设的市场有多大工具型网站有哪些
  • 邢台网站建设优化茶叶网站设计
  • 九江有没有做网站的公司郑州小程序开发外包
  • 做网站做得好的公司有网站建设案例信息
  • 泉州刺桐古建筑公司网站德州百度推广公司
  • 宁波网站建设哪里有怎么做二次元网站源码