面经笔记

1.

输入一串用空格隔开的数字串,对于数字串的奇数位按升序排序,偶数位按降序排序。

示例输入:

4 6 2 3 6 7 8 1

处理过程:

奇数位:4 2 6 8 升序排序结果: 2 4 6 8

偶数位:6 3 7 1 降序排序结果: 7 6 3 1

结果输出:2 7 4 6 6 3 8 1

 1 import java.util.ArrayList;
 2 import java.util.PriorityQueue;
 3 import java.util.Scanner;
 4
 5 /**
 6  * Created by Mingxiao on 10/14/2016.
 7  * Time: O(N*logN)
 8  * Space: O(N)
 9  */
10 public class Main {
11
12     public int[] sort(int[] arr) {
13         if (arr == null || arr.length <= 1) {
14             return arr;
15         }
16
17         PriorityQueue<Integer> increaseQueue = new PriorityQueue<>();
18         PriorityQueue<Integer> decreaseQueue = new PriorityQueue<>();
19         int[] result = new int[arr.length];
20
21         int oddIndex = 1;
22         int evenIndex = 0;
23
24         while (oddIndex < arr.length) {
25             decreaseQueue.offer(arr[oddIndex]);
26             increaseQueue.offer(arr[evenIndex]);
27
28             oddIndex += 2;
29             evenIndex += 2;
30         }
31
32         oddIndex -= 2;
33         evenIndex = 0;
34
35         while (evenIndex < arr.length && oddIndex > 0) {
36             result[evenIndex] = increaseQueue.poll();
37             result[oddIndex] = decreaseQueue.poll();
38             evenIndex += 2;
39             oddIndex -= 2;
40         }
41
42         return result;
43     }
44
45     public static void main(String[] args) {
46
47         Scanner cin = new Scanner(System.in);
48         ArrayList<Integer> list = new ArrayList<>();
49         while (cin.hasNext()) {
50             list.add(cin.nextInt());
51         }
52
53
54         int[] testArr = new int[list.size()];
55         for (int i = 0; i < list.size(); i++) {
56             testArr[i] = list.get(i);
57         }
58         int[] result = new Main().sort(testArr);
59         for (int i = 0; i < result.length; i++) {
60             System.out.print(result[i] + ", ");
61         }
62     }
63 }

2.

某个字符串只存在三种格式字符分别是0~9、A~Z和a~z,请按照数字在前、大写字母次之、小写字母最后的方式排序,字符串长度不超过100。

例如:CBA321zyx

123ABCxyz

 1 import java.util.Scanner;
 2
 3 /**
 4  * Created by Mingxiao on 10/14/2016.
 5  * Time: O(N)
 6  * Space: O(N)
 7  */
 8 public class Main {
 9
10     public static String sort(String str) {
11         char[] sortArr = new char[128];
12         StringBuilder sb = new StringBuilder();
13
14         for (int i = 0; i < str.length(); i++) {
15             sortArr[str.charAt(i) - 0]++;
16         }
17
18         for (int i = 48; i < sortArr.length; i++) {
19             if (sortArr[i] != 0) {
20                 char temp = (char)i;
21                 for (int j = 0; j < sortArr[i]; j++) {
22                     sb.append(temp);
23                 }
24             }
25         }
26
27         return sb.toString();
28     }
29
30
31     public static void main(String[] args) {
32
33         Scanner cin = new Scanner(System.in);
34         String str = "";
35         while (cin.hasNext()) {
36             str = cin.nextLine();
37         }
38
39         System.out.print(sort(str));
40     }
41 }

3.

给出两个字串A,B。将A字串转化为B字串,转化一共有两种方式:删除连续的n个字符,一次操作费用为2。增加连续的n个字符(增加的字符是什么由你决定),一次操作费用为n+2。求把A变为B最小费用。

dsafsadfadf -> fdfd : 7
aaaaaaaa -> bbbbbbbb: 12提示:"dsafsadfadf" 变成 "fdfd" 最少的代价的一种方法是:1. "dsafsadfadf" -> "f" 删除连续的10个,代价22. "f" -> "fdfd" 增加连续的3个(”dfd”),代价为3 + 2 = 5总共的最小代价为2 + 5 = 7,其他方法的代价都不小于7"aaaaaaaa" 变成 “bbbbbbbb” 最小代价的一种方法是:1. "aaaaaaaa" 全部删除,代价22. 增加8个连续的‘b‘,代价10总共的最小代价为2 + 10 = 12注意,有些最优的方案可能要做多次的删除和增加操作,不限于两次。
 1 import java.util.Scanner;
 2
 3 /**
 4  * Created by Mingxiao on 10/14/2016.
 5  * dp
 6  * Time: O(N^3)
 7  */
 8 public class Main {
 9
10     private static final int BOUND = 2000;
11     private static final int INF = Integer.MAX_VALUE;
12
13     public static int minCost(String a, String b) {
14         int l1 = a.length();
15         int l2 = b.length();
16         int[][] first = new int[BOUND][BOUND];
17         int[][] second = new int[BOUND][BOUND];
18         int[][] third = new int[BOUND][BOUND];
19
20         for (int i = 0; i <= l1; i++) {
21             first[0][i] = 2; second[0][i] = third[0][i] = INF;
22         }
23         for (int i = 0; i <= l2; i++) {
24             second[i][0] = i + 2; first[i][0] = third[i][0] = INF;
25         }
26         third[0][0] = 0;
27         for (int j = 1; j <= l2; j++) {
28             for (int i = 1; i <= l1; i++) {
29                 third[j][i] = a.charAt(i - 1) == b.charAt(j - 1) ? Math.min(Math.min(third[j - 1][i - 1], second[j - 1][i - 1]), first[j - 1][i - 1]) : INF;
30                 second[j][i] = first[j][i] = INF;
31                 for (int k = 1; k <= j; k++) {
32                     second[j][i] = Math.min(second[j][i], Math.min(second[j - k][i] + k, Math.min(first[j - k][i] + k + 2, third[j - k][i] + k + 2)));
33                 }
34                 for (int k = 1; k <= i; k++) {
35                     first[j][i] = Math.min(first[j][i], Math.min(first[j][i - k], Math.min(second[j][i - k] + 2, third[j][i - k] + 2)));
36                 }
37             }
38         }
39         return Math.min(Math.min(third[l2][l1], second[l2][l1]), first[l2][l1]);
40     }
41
42     public static void main(String[] args) {
43
44         int counter = 0;
45
46         Scanner cin = new Scanner(System.in);
47         if (cin.hasNext()) {
48             counter = cin.nextInt();
49         }
50
51         String[] strArr = new String[counter * 2];
52         int index = 0;
53         while (cin.hasNext()) {
54             strArr[index] = cin.nextLine();
55         }
56
57         for (int i = 0; i < strArr.length; i++) {
58             System.out.println(minCost(strArr[i],strArr[++i]));
59         }
60
61     }
62 }
时间: 2024-10-25 11:50:14

面经笔记的相关文章

【安全牛学习笔记】

弱点扫描 ╋━━━━━━━━━━━━━━━━━━━━╋ ┃发现弱点                                ┃ ┃发现漏洞                                ┃ ┃  基于端口五福扫描结果版本信息(速度慢)┃ ┃  搜索已公开的漏洞数据库(数量大)      ┃ ┃  使用弱点扫描器实现漏洞管理            ┃ ╋━━━━━━━━━━━━━━━━━━━━╋ [email protected]:~# searchsploit Usage:

51CTO持续更新《通哥的运维笔记》

<通哥的运维笔记>将持续在51CTO网站更新,希望大家多多关注.互相学习,后期,我将会退出<通哥的运维笔记>系列视频教程,希望带给大家最大的收获,帮助大家更好的学习.进步.<通哥的运维笔记>主要从linux系统管理.虚拟化.cloudstack云平台以及网络管理之CCNA.CCNP.CCIE,等等方面深入讲解.

WPF笔记整理 - Bitmap和BitmapImage

项目中有图片处理的逻辑,因此要用到Bitmap.而WPF加载的一般都是BitmapImage.这里就需要将BitmapImage转成Bitmap 1. 图片的路径要用这样的,假设图片在project下的Images目录,文件名XXImage.png. pack://application:,,,/xxx;component/Images/XXImage.png 2. 代码: Bitmap bmp = null; var image = new BitmapImage(new Uri(this.X

java String 类 基础笔记

字符串是一个特殊的对象. 字符串一旦初始化就不可以被改变. String s = "abc";//存放于字符串常量池,产生1个对象 String s1=new String("abc");//堆内存中new创建了一个String对象,产生2个对象 String类中的equals比较字符串中的内容. 常用方法: 一:获取 1.获取字符串中字符的个数(长度):length();方法. 2.根据位置获取字符:charAt(int index); 3.根据字符获取在字符串中

vector 学习笔记

vector 使用练习: /**************************************** * File Name: vector.cpp * Author: sky0917 * Created Time: 2014年04月27日 11:07:33 ****************************************/ #include <iostream> #include <vector> using namespace std; int main

学习笔记之邮件发送篇

用脚本语言发送邮件是系统管理员必备技能 对系统定期检查或者当服务器受到攻击时生成文档和报表. 发布这些文档最快速有效的方法就是发送邮件. python中email模块使得处理邮件变得比较简单 发送邮件主要用到了smtplib和email两个模块,这里首先就两个模块进行一下简单的介绍: 本段摘录于    http://www.cnblogs.com/xiaowuyi/archive/2012/03/17/2404015.html 1.smtplib模块 smtplib.SMTP([host[, p

15.1-全栈Java笔记:Java事件模型是什么?事件控制的过程有哪几步??

应用前边两节上一章节的内容,大家可以完成一个简单的界面,但是没有任何的功能,界面完全是静态的,如果要实现具体功能的话,必须要学习事件模型. 事件模型简介及常见事件模型 对于采用了图形用户界面的程序来说,事件控制是非常重要的. 一个源(事件源)产生一个事件并把它(事件对象)送到一个或多个监听器那里,监听器只是简单地等待,直到它收到一个事件,一旦事件被接收,监听器将处理这些事件. 一个事件源必须注册监听器以便监听器可以接收关于一个特定事件的通知. 每种类型的事件都有其自己的注册方法,一般形式为: v

Java设计模式学习笔记,一:单例模式

开始学习Java的设计模式,因为做了很多年C语言,所以语言基础的学习很快,但是面向过程向面向对象的编程思想的转变还是需要耗费很多的代码量的.所有希望通过设计模式的学习,能更深入的学习. 把学习过程中的笔记,记录下来,只记干货. 第一部分:单例模式的内容 单例模式:类只能有一个实例. 类的特点:1.私有构造器:2.内部构造实例对象:3.对外提供获取唯一实例的public方法. 常见的单例模式实现有五种形式: 1.饿汉式. 2.懒汉式. 3.双重检查锁式. 4.静态内部类式. 5.枚举式. 以下分别

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则 用了几天时间看了一下开源框架Caliburn.Micro 这是他源码的地址http://caliburnmicro.codeplex.com/ 文档也写的很详细,自己在看它的文档和代码时写了一些demo和笔记,还有它实现的原理记录一下 学习Caliburn.Micro要有MEF和MVVM的基础 先说一下他的命名规则和引导类 以后我会把Caliburn.Micro的 Actions IResult,IHandle ICondu

机器学习笔记_PRML_Adaboost 算法的原理与推导

转自:http://blog.csdn.net/v_july_v/article/details/40718799 Adaboost 算法的原理与推导 1 Adaboost的原理 1.1 Adaboost是什么 AdaBoost,是英文"Adaptive Boosting"(自适应增强)的缩写,由Yoav Freund和Robert Schapire在1995年提出.它的自适应在于:前一个基本分类器分错的样本会得到加强,加权后的全体样本再次被用来训练下一个基本分类器.同时,在每一轮中加