博客
关于我
牛客刷题组队竞速,删除公共字符,最长的数字串
阅读量:588 次
发布时间:2019-03-11

本文共 2498 字,大约阅读时间需要 8 分钟。

组队竞速

牛牛举办了一场编程比赛,共有3*n个选手参加。每个选手都有一个水平值a_i。牛牛的目标是将选手分成n组,每组3人,要求每组的水平值等于该组队员中第二高的水平值。牛牛希望通过合理分组,使得所有队伍的水平值总和最大化。

解题思路

为了最大化所有队伍的水平值总和,每个队伍的第二个值应尽可能大。因此,合理的策略是将选手按水平值从小到大排序后,将最大的n个水平值放在右边的两端,中间的n个水平值放在左边。这样可以确保中间的水平值尽量大,进而使得每个队伍的第二个值最大。

解决代码

import java.util.*;public class Main{    public static void main(String[] args) {        Scanner scan = new Scanner(System.in);        int n = scan.nextInt();        int[] array = new int[3 * n];        for (int i = 0; i < 3 * n; i++) {            array[i] = scan.nextInt();        }        Arrays.sort(array);        long sum = 0;        for (int i = 1; i < 3 * n; i++) {            if (i % 4 == 0) {                if (i == 3 * n - 1) {                    sum += array[i];                }            } else {                sum += array[i];            }        }        System.out.println(sum);    }}

删除公共字符

输入两个字符串str1和str2,从str1中删除str2中所有的字符。例如,输入“They are students.”和“aeiou”,则删除后的字符串变为“Thy r stdnts.”。

解决方法

  • 首先,遍历str2,将每个字符存储在集合中。
  • 然后,遍历str1,检查每个字符是否存在于集合中,如果不存在,则保留该字符。
  • 将处理后的字符串输出。
  • 解决代码

    import java.util.*;public class Main{    public static void main(String[] args) {        Scanner scan = new Scanner(System.in);        String str1 = scan.nextLine();        String str2 = scan.nextLine();        Map
    map = new HashMap<>(); for (int i = 0; i < str2.length(); i++) { map.put(str2.charAt(i), i); } StringBuilder sb = new StringBuilder(str1); for (int i = 0; i < sb.length(); i++) { if (!map.containsKey(sb.charAt(i))) { char c = sb.charAt(i); sb.deleteCharAt(i); } } System.out.println(sb.toString()); }}

    最长的数字串

    读取一个字符串str,找出其中连续最长的数字串。

    解决方法

  • 初始化两个字符串变量curret,分别用于记录当前和最长的数字串。
  • 遍历输入字符串中的每一个字符:
    • 如果字符是数字,则添加到当前字符串cur中。
    • 如果不是数字,则比较curret的长度,保留较长的字符串,并重置cur为空。
  • 遍历结束后,比较curret,保留最长的数字串。
  • 输出最长数字串。
  • 解决代码

    import java.util.*;public class Main{    public static void main(String[] args) {        Scanner scan = new Scanner(System.in);        String str = scan.nextLine();        String cur = "";        String ret = "";        for (int i = 0; i < str.length(); i++) {            char ch = str.charAt(i);            if (ch >= '0' && ch <= '9') {                cur += ch;            } else {                if (cur.length() > ret.length()) {                    ret = cur;                }                cur = "";            }        }        if (cur.length() > ret.length()) {            ret = cur;        }        System.out.println(ret);    }}

    转载地址:http://qsstz.baihongyu.com/

    你可能感兴趣的文章
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—3.Reactor线程模型三
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—5.Pipeline和Handler二
    查看>>
    Netty源码—6.ByteBuf原理一
    查看>>
    Netty源码—6.ByteBuf原理二
    查看>>
    Netty源码—7.ByteBuf原理三
    查看>>
    Netty源码—7.ByteBuf原理四
    查看>>
    Netty源码—8.编解码原理一
    查看>>
    Netty源码—8.编解码原理二
    查看>>
    Netty源码解读
    查看>>
    Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
    查看>>
    Netty相关
    查看>>
    Netty遇到TCP发送缓冲区满了 写半包操作该如何处理
    查看>>
    Netty:ChannelPipeline和ChannelHandler为什么会鬼混在一起?
    查看>>
    Netty:原理架构解析
    查看>>
    Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
    查看>>