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
- NRVO
- winapi
- 티스토리챌린지
- Unreal Engine5
- UnrealEngine5
- 줄 세우기
- RVO
- Programmers
- C
- GeeksForGeeks
- directx
- UE5
- 언리얼엔진5
- 1563
- const
- algorithm
- UnrealEngine4
- 프로그래머스
- 팰린드롬 만들기
- 백준
- baekjoon
- 오블완
- C++
- 2294
- softeer
- Frustum
- DeferredRendering
- DirectX11
- RootMotion
- IFileDialog
Archives
- Today
- Total
Game Develop
[Algorithm]Baekjoon 2607번 :: 비슷한 단어 본문
각 알파벳횟수를 벡터에 인덱싱 후, 횟수 비교.
다른알파벳횟수가 2개이하이고, 문자열길이가 1이하면 count++.
처음 접근은 괜찮게했는데 다른알파벳횟수를 1개이하라 생각했었다.
그런데 AAAB ,ABBA 경우 비슷한단어인데 다른알파벳횟수가 2회라서 예외가 났다.
각각 횟수가 기준문자열 A(3),B(1) 이고 비교문자열이 A(2),B(1)이라서 횟수가 2가나온다.
혹시나 다른 케이스가 더 있나 생각해봤는데 2가 컷트라인이 맞는것같다.
AAAB,ABBA는 문자자체는 같은문자로 이루어져있기때문에 다른 예제들에 비해 좀 더 비슷한단어인데, 여기서 2가나왔으니..
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
#include<iostream>
#include<string>
#include<vector>
#include<algorithm>
using namespace std;
vector<string> sv;
vector<string> testsv;
vector<int> standIndex(26);
vector<int> tempIndex(26);
int solution()
{
string stand = sv[0]; // 기준 단어.
int result = 0;
for (int i = 0; i < stand.size(); i++)
{
standIndex[(size_t)stand[i] - 65] += 1;
}
for (int i = 1; i < sv.size(); i++)
{
int count = 0;
string temp = sv[i];
memset(tempIndex.data(), 0, sizeof(int) * 26);
for (int j = 0; j < temp.size(); j++)
{
tempIndex[temp[j] - 65] += 1;
}
for (int i = 0; i < 26; i++)
{
if (standIndex[i] != tempIndex[i])
{
count += abs(standIndex[i] - tempIndex[i]);
}
}
if (count <= 2 && abs((int)stand.size() - (int)temp.size()) <= 1)
{
result++;
}
}
return result;
}
int main()
{
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
int n = 0;
string s = "";
cin >> n;
for (int i = 0; i < n; i++)
{
cin >> s;
sv.push_back(s);
}
int result = solution();
cout << result;
}
|
cs |
'Algorithm > Baekjoon' 카테고리의 다른 글
[Algorithm]Baekjoon 1759번 : 암호 만들기 (0) | 2022.07.18 |
---|---|
[Algorithm]Baekjoon 1182번 : 부분수열의 합 (0) | 2022.07.17 |
[Algorithm]Baekjoon 1922번 :: 네트워크 연결(크루스칼 알고리즘) (0) | 2022.07.09 |
[Algorithm]Baekjoon 1753번 :: 최단거리(다익스트라 알고리즘) (0) | 2022.07.05 |
[Algorithm] 백준문제 C++로 풀 때 주의할 점 (입출력관련) (0) | 2022.05.15 |