首页 > 其他 > 详细

编辑和剪绳子-头条2019笔试题

时间:2020-05-25 22:52:10      阅读:49      评论:0      收藏:0      [点我收藏+]

万万没想到之聪明的编辑-头条2019笔试题

千万不要在原字符串上直接进行删除操作,否则删除操作时间复杂度\(O(n)\),会超时、超时、超时
考点:双指针算法

import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        while(n-- > 0) {
            String str = sc.next();
            char[] s = str.toCharArray();
            int j = 0;
            for(int i=0; i < s.length; i++) {
                s[j++] = s[i];
                if(j-3 >= 0 && s[j-3] == s[j-2] && s[j-2] == s[j-1]) {
                    j--;
                }
                else if(j-4 >= 0 && s[j-4] == s[j-3] && s[j-3] != s[j-2] && s[j-2] == s[j-1]) {
                    j--;
                }
            }
            StringBuilder sb = new StringBuilder();
            for(int k=0; k < j; k++)
                sb.append(s[k]);
            System.out.println(sb.toString());
        }
    }
}

剪绳子-头条2019笔试题

二分查找答案
时间复杂度\(O(NlogL)\)
计算次数: \(N \times log_2^{10^9 \times 10^3} = 10^5 * log_2^{10^{12}} = 10^5 \times log10^{12}/log2 \approx 12/0.3 \times 10^5 = 4.0 \times 10^6\)

import java.util.*;
public class Main{
    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt(), m = sc.nextInt();
        int[] arr = new int[n];
        for(int i=0; i < n; i++)
            arr[i] = sc.nextInt();
        double l = 0, r = 1000000000D;
        while(Math.abs(r-l) > 0.001) {
            double mid = (l+ r) / 2.0;
            int cnt = 0;
            for(int i=0; i < n; i++) {
                cnt += (int) ((double)arr[i] / mid);
            }
            if(cnt >= m) l = mid;
            else r = mid;
        }
        // System.out.println(r);
        System.out.printf("%.2f", r);
    }
}

编辑和剪绳子-头条2019笔试题

原文:https://www.cnblogs.com/lixyuan/p/12956831.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!