> Java > Java시작하기 > Java에서 문자열 압축을 구현하는 방법

Java에서 문자열 압축을 구현하는 방법

王林
풀어 주다: 2020-03-17 17:37:47
앞으로
4156명이 탐색했습니다.

string 스트링 압축에 대한 이중 포인터 사용

Java에서 문자열 압축을 구현하는 방법

예 :

public static void zipStr(String str) {
		char[] c = str.toCharArray();
		int index = 0;
		int num = 1;
		int len = c.length;
		while (index < len - 1) {
			while (c[index] == c[index + 1]) {
				num++;
				index++;
				if (index >= len - 1) {
					break;
				}
			}
			System.out.print(c[index]);
			System.out.print(num);
			num = 1;
			index++;
		}
	}
로그인 후 복사
결과는 다음과 같습니다. 형식(aaabbbcccc)의 경우 압축 결과는 a3b3c3이지만 형식(acaadbbcceeeffffff)의 문자열에 대한 압축 결과는 a1c1a2d1b3c2e3f6입니다. 분명히 이 결과는 무리이므로 다음에는 문자열 압축에 HashMap을 사용하세요

문자 압축에는 HashMap을 사용하세요. 압축

예:

public static HashMap fun1(String str) {
		HashMap<Character, Integer> map = new HashMap<Character, Integer>();
		char[] c = str.toCharArray();
		for (int i = 0; i < c.length; i++) {
			Integer count = map.get(c[i]);//此处的count的类型一定要为Integer,如果为int类型,则count值为0
			if (!map.containsKey(c[i])) {
				map.put(c[i], 1);
			} else {
				map.put(c[i], count + 1);
			}
		}
		return map;
	}
로그인 후 복사
Java에서 문자열 압축을 구현하는 방법결과는 그림과 같습니다.

추천 관련 비디오 튜토리얼:

java 비디오 튜토리얼

위 내용은 Java에서 문자열 압축을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:csdn.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿