반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 리액트
- 정보처리기사실기
- 자바의정석
- javascript
- 오라클
- react
- 스프링
- 이안의평일코딩
- 정보처리기사
- 자바스크립트
- 자스코테
- Java의정석
- Oracle
- 국비IT
- spring
- VUE
- 정보처리기사정리
- typescript
- CSS
- 타입스크립트
- 국비코딩
- 정보처리기사요약
- 정보처리기사실기요약
- 자바스크립트 코딩테스트
- 정보처리기사실기정리
- php
- 평일코딩
- ReactNative
- 코딩테스트
- 리액트네이티브
Archives
- Today
- Total
이안의 평일코딩
[JS] 기초 (2) - 문자대체, 찾기, 개수, 중복제거, 대소문자 변환 본문
반응형
문자대체
.replace(/원래문자/, '변경할문자');
<script>
function solution(s){
// 첫번째 방법
let answer="";
for (let x of s){
if(x==='A') answer+='#';
else answer+=x;
}
return answer;
}
let str="BANANA";
console.log(solution(str));
</script>
<script>
function solution(s){
// 두번째 방법
let answer=s;
answer=answer.replace(/A/g, '#'); // g 전역
return answer;
}
let str="BANANA";
console.log(solution(str));
</script>
문자찾기
.split(a) a에 해당하는 문자를 잘라낸다
<script>
function solution(s, t){
// 첫번째 방법
let answer=0;
for(let x of s){
if(x===t) answer++;
}
return answer;
}
let str="COMPUTERPROGRAMMING";
console.log(solution(str, 'R'));
</script>
<script>
function solution(s, t){
// 두번째 방법
let answer=s.split(t).length; // (4) ["COMPUTE", "P", "OG", "AMMING"]
return answer-1; // 마지막 문자여도 "" 빈 문자열이 들어가므로 동일하다
}
let str="COMPUTERPROGRAMMING";
console.log(solution(str, 'R'));
</script>
대문자찾기
.toUpperCase() 대문자로 변경
.charCodeAt() ASCII코드로 변경. 대문자 65~90, 소문자 97~122
<script>
function solution(s){
let answer=0;
// 첫번째 방법
for(let x of s){
if(x===x.toUpperCase()) answer++; // K === K, o === O, r === R...
}
return answer;
}
let str="KoreaTimeGood";
console.log(solution(str));
</script>
<script>
function solution(s){
let answer=0;
// 두번째 방법
for(let x of s){
let num=x.charCodeAt(); // ASCII코드 대문자 65~90 소문자 97~122
if(num>=65 && num<=90) answer++;
}
return answer;
}
let str="KoreaTimeGood";
console.log(solution(str));
</script>
대문자로 통일
<script>
function solution(s){
let answer="";
// 첫번째 방법
for(let x of s){
if(x===x.toLowerCase()) answer+=x.toUpperCase(); //소문자면 대문자로 바꿈
else answer+=x;
}
return answer;
}
let str="ItisTimeToStudy";
console.log(solution(str));
</script>
ASCII 소문자 a 97, 대문자 A 65. 차이는 32
<script>
function solution(s){
let answer="";
// 두번째 방법 ASCII
for(let x of s){
let num=x.charCodeAt(); // String.fromcharCode()는 괄호안을 문자열로 반환한다
if(num>=97 && num<=122) answer+=String.fromCharCode(num-32);
else answer+=x;
}
return answer;
}
let str="ItisTimeToStudy";
console.log(solution(str));
</script>
대소문자 변환
.toUpperCase()
.toLowerCase()
<script>
function solution(s){
let answer="";
for(let x of s){
if(x===x.toUpperCase()) answer+=x.toLowerCase();
else answer+=x.toUpperCase();
}
return answer;
}
console.log(solution("StuDY"));
</script>
가장 긴 문자열
Number.MIN_SAFE_INTEGER 최대값을 찾기위해 먼저 가장 작은 정수로 잡는다.
<script>
function solution(s){
let answer, max=Number.MIN_SAFE_INTEGER;
for(let x of s){
if(x.length>max){
max=x.length;
answer=x;
}
}
return answer;
}
let str=["teacher", "time", "student", "beautiful", "good"];
console.log(solution(str));
</script>
가운데 문자 출력
Math.floor() 소수점 내림, 나눈 몫 구하기
.substring(2, 4) : 2번 인덱스부터 3번 인덱스까지. length => ng
.substr(2, 4) : 2번 인덱스부터 4개 뽑아냄. length => ngth
s.substring(mid, mid+1) => s.substr(mid, 1);
s.substring(mid-1, mid+1) => s.substr(mid-1, 2);
<script> // good이면 oo, top 이면 o
function solution(s){
let answer;
let mid=Math.floor(s.length/2); // 단어를 길이를 2로 나눈 몫 floor는 내림 (소수점 날림)
if(s.length%2==1) answer=s.substring(mid, mid+1); // 홀수일 때 mid부터 mid+1 전까지
else answer=s.substring(mid-1, mid+1); // 짝수일 때 4/2 good는 두번째 o가 2번째
return answer;
}
console.log(solution("study"));
</script>
중복문자 제거
.indexOf('k') : 처음 발견하는 곳 -> 위치 0
.indexOf('k', 1) : 1번부터 찾아라 -> 위치 3
<script>
function solution(s){
let answer="";
for(let i=0; i<s.length; i++){
console.log(s[i], i, s.indexOf(s[i]));
// k 0 0, s 1 1, e 2 2, k 3 0, k 4 0, s 5 1, e 6 2, t 7 7
if(s.indexOf(s[i])===i) answer+=s[i];
// 최초의 문자 인덱스번호와 본래 위치가 일치할 때 첫번째로 발견된 것
}
return answer;
}
console.log(solution("ksekkset")); //kset
</script>
특정문자 개수
.indexOf('K') : 발견못할 때 -> 위치 -1
<script>
function solution(s){
let answer=0;
let pos=s.indexOf('k');
console.log(s.indexOf('k')); // 0
while(pos!==-1){ // indexOf()가 -1면 찾지 못한것이므로 특정문자 찾았을때 반복문
console.log(pos); // 0, 3, 4
answer++; // 찾으면 카운팅
pos=s.indexOf('k', pos+1); // pos 첫번째 찾은 그 위치 뒷편부터 찾아라
}
return answer;
}
console.log(solution("ksekkset"));
</script>
중복단어 제거
.filter() 배열 filter함수 조건만족하는 것만 return받아서 새로운 배열을 만듦
s.filter((v, i) => {}) : v는 s라는 배열의 값들, i는 인덱스
<script>
function solution(s){
let answer;
console.log(s.indexOf("good")); // 0, "time"은 1, "student"는 4
answer=s.filter((v, i) => {
console.log(v, i); // good 0, time 1, good 2, time 3, student 4
if(s.indexOf(v)===i) return v; // 일치하면 처음 나온 것
});
return answer;
}
let str=["good", "time", "good", "time", "student"];
console.log(solution(str));
</script>
반응형
'Study > JS Algorithm Rocket' 카테고리의 다른 글
[모집] 자바스크립트 알고리즘 로켓스터디 (0) | 2021.08.23 |
---|---|
[JS] 완전탐색 (브루트포스) (0) | 2021.05.26 |
[JS] 문자열탐색 (회문, 팰린드롬, 추출, 최단거리, 압축) (0) | 2021.05.25 |
[JS] 1, 2차원 배열 탐색 (가위바위보, 등수, 격자판, 봉우리) (0) | 2021.05.24 |
[JS] 기초 (1) - 최솟값, 삼각형, 개수, 합, 홀수, 10부제, 일곱난쟁이 (0) | 2021.05.17 |
Comments