文档章节

一道笔试题

小强零号
 小强零号
发布于 2015/10/15 23:31
字数 535
阅读 135
收藏 7

样例输入:

asdfetgfg
123df43
hg1234ds4321
a234dsf567sd657

样例输出:

null
123
1234
567

示例解题代码(Java):

import java.util.ArrayList;
import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		
		Scanner sc = new Scanner(System.in);
		ArrayList<String> strs = new ArrayList<String>();
		
		//输入字符串
		while(sc.hasNextLine()) {
			String temp = sc.nextLine();
			if(temp.equals(""))
				break;
			strs.add(temp);
		}
		//关闭Scanner
		sc.close();
	
	        //运行查找函数
		for(int i = 0; i < strs.size(); i++) {
			System.out.println(getMaxSubStr(strs.get(i)));
		}
	}
	
	public static String getMaxSubStr(String source) {
		
		//抽取出source中的数字串
		ArrayList<String> numbers = new ArrayList<String>();
		int start = 0;
		for(int i = 0; i < source.length(); i++) {
			while(i < source.length() && !Character.isDigit(source.charAt(i))) {
				i++;
			}
			start = i;
			while(i < source.length() && Character.isDigit(source.charAt(i))) {
				i++;
			}
			if(i - start > 1) {
				numbers.add(source.substring(start, i));
			}
		}
		
		//如果source中不含数字子串,则返回null
		if(numbers.size() == 0) return null;
		
		//找数字子串List中长度最大的串的下标maxIndex,比较时用小于号,这样找出的是第一个最长子串
		int maxIndex = 0;
		for(int i = 1; i < numbers.size(); i++) {
			if(numbers.get(maxIndex).length() < numbers.get(i).length()) {
				maxIndex = i;
			}
		}
		
		//查找最长数字子串是否唯一,在maxIndexs中存放最长数字子串的下标
		ArrayList<Integer> maxIndexs = new ArrayList<Integer>();
		for(int i = 0; i < numbers.size(); i++) {
			if(numbers.get(maxIndex).length() == numbers.get(i).length()) {
				maxIndexs.add(i);
			}
		}
		
		//如果最长数字子串不唯一(即maxIndexs长度大于1),则找出其中各字符对应数字之和最大的那个
		if(maxIndexs.size() > 1) {
		        //计算每个最长子串各字符对应数字之和,存放在num数组中,num数组和maxIndexs一一对应
			int[] num = new int[maxIndexs.size()];
			for(int i = 0; i < maxIndexs.size(); i++) {
				for(int j = 0; j < numbers.get(maxIndexs.get(i)).length(); j++) {
					num[i] += "0123456789".indexOf(numbers.get(maxIndexs.get(i)).charAt(j));
				}
			}
			//找出num中最大值的下标,通过maxIndexs找到这个下标所对应的numbers中的子串下标
			int index = 0;
			for(int i = 1; i < maxIndexs.size(); i++) {
				if(num[index] < num[i])
					index = i;
			}
			//maxIndex得到目标子串在numbers中的下标
			maxIndex = maxIndexs.get(index);
		}
		
		//返回目标子串
		return numbers.get(maxIndex);
	}

}

getMaxSubStr()的计算流程:


© 著作权归作者所有

共有 人打赏支持
小强零号
粉丝 6
博文 31
码字总数 12473
作品 0
长宁
程序员
18届清华硕士狂拿18家互联网公司offer

2018校招总结(外企,国内大公司,国内创业公司) 本篇是我参加2018春招实习和秋招的求职经历,除了笔试面试中遇到的一些问题,更多的是一些个人想法。 春招和秋招面了不少公司,实习offer有...

野梦M
2017/12/18
0
1
HR怎么从面试中了解程序员的真实水平?

HR肯定不懂或至少不太懂专业技术,这点,是一定的。 一个外行,怎么面试内行,很多求职者会很好奇。 其实,HR初试,更多的是看“人怎么样”,对“能力行不行”的观察,只是一个大概的情况,后...

明哥聊求职
2017/11/27
0
0
请教各位朋友们,django如何实现在线笔试系统

各位朋友们好,最近有在做在线笔试系统,在数据库里建立用户表,试卷表,用户笔试得分表,但是具体地如何在点击下一题显示下一道题目,在最后提交的时候,把结果进行提交,并如何评判笔试结果...

qingyuanlu
2015/09/28
130
0
一道算法笔试题,大家来看看

最近校园招聘比较火爆,参加了不少公司的笔试,昨天的网康笔试里有一道算法题,大家来看看怎么做: 大概是这样的:N个人围成一个圆圈,从某个人开始报数,报数为K的倍数的人退出这个圆圈,其...

YueZheng
2012/10/24
505
7
一个找规律的题目,小弟驽钝

77 49 36 () 8,括号内该填啥,一道笔试题,不得其解

Padding
2012/12/24
317
7

没有更多内容

加载失败,请刷新页面

加载更多

下一页

nginx访问日志-日志切割-静态文件不记录日志和过期时间

nginx访问日志: vim /usr/local/nginx/conf/nginx.conf #搜索log_format 该字段定义日志格式,默认如下: #combined_realip日志格式的名字,可随意定义; 定义访问日志: 需在虚拟主机配置文...

ZHENG-JY
1分钟前
0
0
180.mariadb 主从复制

参考:https://blog.csdn.net/chengxuzaza/article/details/62042920 睡觉睡觉,明天写 1.效果 当主库中数据有变化的时候,从库就自动同步 2. 环境要求 至少两台 linux服务器 (教程:https...

Lucky_Me
11分钟前
0
0
erlng file id3v1 id3v1.1

%% ---%% Excerpted from "Programming Erlang",%% published by The Pragmatic Bookshelf.%% Copyrights apply to this code. It may not be used to create training material, %% ......

xueyuse0012
12分钟前
1
0
RabbitMq的安装

环境Centos6.5 32位 JDK 1.7.8 Jdk的卸载 rpm -qa|grep jdk yum –y remove 上边的安装包 JDK的安装 Rpm –ivh jdk安装包 配置环境变量 export JAVA_BIN=/usr/java/jdk1.7.0_80/bin export J......

DemonsI
16分钟前
0
0
http和https协议

HTTPS全称为Hypertext Transfer Protocol over Secure Socket Layer,中文含义为“超文本传输协议在安全加密字层”,简单来说就是加密数据传输,通俗的说就是安全连接。 HTTPS安全超文本传输...

寰宇01
22分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部