전체 글
[브1] 1356 - 유진수
#include #include using namespace std;int main() { string N; cin >> N; int tempLeft = 1; for (int i = 0; i
[Unreal] EnhancedInput 시스템이란?
언리얼 엔진 5의 Enhanced Input 시스템은 기존의 입력 시스템(Input System)을 대체하여 보다 유연하고 강력한 입력 처리를 제공한다. 이 시스템은 다양한 입력 디바이스를 통합 관리하고, 더 복잡한 입력 매핑과 처리 로직을 지원한다. Enhanced Input의 주요 개념Input Mapping Contexts:입력 맵핑 컨텍스트는 여러 입력 액션(Input Actions)을 그룹화하는 역할을 한다.특정 상황이나 상태에서 활성화될 수 있으며, 여러 컨텍스트를 겹쳐 사용할 수 있다.예를 들어, 걷기 상태와 운전 상태에 따라 다른 입력 맵핑 컨텍스트를 사용할 수 있다.Input Actions:입력 액션은 단일 입력 이벤트(키 누르기, 마우스 클릭 등)를 나타낸다.디지털 입력(키보드, 버튼..
[C++] cin.ignore와 버퍼에 대한 이해
cincin은 character input의 약자로, 버퍼의 값을 읽어온다. 만약 버퍼에 읽어올 값이 없으면 표준 입력 스트림으로부터 입력을 받아와 버퍼에 저장하고나서 버퍼의 값을 읽어온다.입력을 받는다는 것이 아닌 버퍼를 먼저 읽으려고 한다는 관점이 중요하다. (버퍼는 자료구조 queue와 유사하다. 선입선출로 작동한다.) cin >>은 공백 (스페이스, 탭, 줄바꿈) 문자를 기준으로 끊어서 읽어오고, 공백문자는 무시한다#include using namespace std;int main() { char name[100]; cout > name; cout 0. 버퍼에 다음과 같이 저장된다. [ j ] [ o ] [ h ] [ n ] [ ' ' ] [ n ] [ a ] [ n ] [ a ]..
[브2] 12605 - 단어순서 뒤집기
이미 cin을 한번 했기 때문에 ignoreint main(){ int n, t = 1; cin >> n; cin.ignore(); while (n--) { string str, tmp; getline(cin, str); stringstream ss(str); stack s; while (ss >> tmp) s.push(tmp); cout
[C++] std::map을 value 기준으로 정렬하기
std::map 정렬map의 자료구조는 기본적으로 key 값 기준 오름차순 기반 정렬을 하고 있다template , // map::key_compare class Alloc = allocator > // map::allocator_type > class map; 만약 우리가 key 값 기준 내림차순으로 변경하기 위해선 3번째 인자에 greater()를 넣어주면 된다// 키, 데이터, comparemap> m;value 값 기반 정렬하기map에는 정렬 함수가 따로 없어서, vector를 활용해야한다. 구체적으로, map은 tree형태로 되어져있고, tree 형태를 만드는 과정에서 key을 기준으로 정렬을 한다. 완성된 tree를 ..
[C++] set, map 정렬 기준 바꾸는 방법
C++ STL에서 제공하는 set, map, multiset, multimap 등의 컨테이너는 자동으로 데이터를 정렬된 상태로 유지시켜 준다. 그래서 이러한 컨테이너에 데이터를 넣고 그대로 출력하기만 하면 오름차순으로 정렬된 데이터를 얻을 수 있지만 가끔은 내림차순 정렬이 필요하거나 내가 원하는 방식대로 정렬되어야 하는 경우도 생긴다. set의 템플릿 (template)을 살펴보면 다음과 같이 되어 있다template , class _Alloc = allocator> _Kty 부분은 흔히 사용하는 키 타입을 설정하는 부분이다. 우리가 봐야 할 부분은 _Pr이다 기본 값으로 less가 설정된 모습을 볼 수 있는데 이 less는 아래와 같이 정의되어 있다template struct less { _CXX..
[실5] 7785 - 회사에 있는 사람
리스트는 O(n^2)이라 시간초과int main(){ int n; cin >> n; list l; while (n--) { string s1, s2; cin >> s1 >> s2; if (s2 == "leave") l.remove(s1); else l.push_back(s1); } l.sort([&](string l, string r) { return l > r; }); while (!l.empty()) { cout 정답) 값 추가할 때마다 재정렬해줌int main(){ int n; cin >> n; set> s; map> m; while (n--) { string s1, s2; cin >> s1 >> s2; if (s2 == "leave") m[s1] = " "; e..
[실4] 14425 - 문자열 집합
int main(){ int n, m; cin >> n >> m; map d; for (int i = 0; i > str; d[str] = true; } int cnt = 0; while (m--) { string str; cin >> str; cnt += d.contains(str); } cout
[실5] 10815 - 숫자 카드
이진 탐색 하기 전 정렬이 되어있어야함 int main(){ int n, m; cin >> n; Vec vn(n); for (int i = 0; i > vn[i]; cin >> m; Vec vm(m); for (int i = 0; i > vm[i]; sort(vn.begin(), vn.end()); for (int i = 0; i
[브1] 1934 - 최소공배수
int gcd(int a, int b){ int r; while (b != 0) { r = a % b; a = b; b = r; } return a;}int lcm(int a, int b){ return (a * b) / gcd(a, b);}int main(){ int t; cin >> t; while (t--) { int a, b; cin >> a >> b; cout