코딩테스트

    [LeetCode] 151. Reverse Words in a String

    내가 작성한 코드reverse(s.begin(), s.end());string str, ans;for (auto iter = s.begin(); iter != s.end(); iter++){ char ch = *iter; if (ch == ' ') { if (str == "") continue; reverse(str.begin(), str.end()); ans += str + ' '; str = ""; } else str += ch;}reverse(str.begin(), str.end());if (str == "") ans.pop_back();return ans + str; 인터넷에서 퍼온 코드stringstream st(s);string word;vector ans;while (st >> ..

    [LeetCode] 45. Jump Game II

    auto size = nums.size();if (size == 1) return 0;int ans = 1, end = nums[0], far = nums[0];for (int i = 0; i = size - 1) break; }}return ans;

    [LeetCode] 55. Jump Game

    bool canJump(vector& nums) { int idx = nums.size() - 1; if (idx == 0) return true; for (int i = idx - 1; i >= 0; i--) { if (nums[i] + i >= idx) idx = i; } return idx == 0;}

    [LeetCode] 136. Single Number

    로직은 단순하다map에 파라미터로 넘어오는 nums의 개수를 파악하고이후 새로운 벡터를 초기화한 후 오름차순 정렬using IntPair = pair;class Solution{public: int singleNumber(vector& nums) { map m; for (auto& item : nums) m[item]++; vector v(m.begin(), m.end()); sort(v.begin(), v.end(), [&](const IntPair& left, const IntPair& right) -> bool { return left.second  xor 방식int singleNumber(vector& nums) { int ans=0; for(auto& it..

    [실3] 1002 - 터렛

    #include #include #include #include #include using namespace std;int main(){ int t; cin >> t; while (t--) { int x1, y1, r1, x2, y2, r2; cin >> x1 >> y1 >> r1 >> x2 >> y2 >> r2; double d = sqrt(pow(x1 - x2, 2) + pow(y1 - y2, 2)); double sub = r1 > r2 ? r1 - r2 : r2 - r1; int sum = r1 + r2; if (d == 0 && r1 == r2) cout sub && d

    [LeetCode] 1 - Two Sum

    class Solution { public: vector twoSum(vector& nums, int target) { unordered_map m; // 예시 2,7,11,15 / 9 for (int i = 0; i 2 : 0 * 9 - 7 = 2 > 2가 존재 * nums[i]=7 > 1, 9 * * int idx = target - nums[i]; if (m.find(idx) == m.end()) m[nums[i]] = i; else return { m[idx],i }; */ /* * 솔루션 2) 해당 값을 조합 * * 9 - 2 = 7 * m에 7이 없음 > m[2] = 0 * * 9 - 7 = ..

    [LeetCode] 6 - Zigzag Conversion

    class Solution { public: string convert(string s, int numRows) { string res; vector v(numRows); auto iter = s.begin(); int idx = 0; bool flag = true; // 1일 때 항상 일치함 if (numRows == 1) return s; // s의 시작점부터 실행 // 로직) 끝에 다다랐을 때 방향을 지정 while (iter != s.end()) { v[idx].push_back(*iter); idx = (flag) ? idx + 1 : idx - 1; if (idx == numRows - 1 || idx == 0) flag = !flag; iter++; } for (const auto& item..

    [LeetCode] Sqrt(x)

    class Solution { public: int mySqrt(int x) { int s = 0, e = x; int ans = 0; while (s x) e = mid - 1; else { ans = mid; s = mid + 1; } } return ans; } };

    [LeetCode] 153. Find Minimum in Rotated Sorted Array

    class Solution { public: int findMin(vector& a) { int low = 0; int high = a.size() - 1; while (low < high) { int mid = low + (high - low) / 2; if (a[mid] < a[high]) high = mid; else low = mid + 1; } return a[low]; } };

    [골3] 2206 - 벽 부수고 이동하기 (최신화)

    3차원 배열 / 메모리 많이 차지함#include #include #include #include #include #include #include #include #include using namespace std;using ll = long long;#pragma region 상하좌우 / 위치const pair dir[]{ { 1, 0 }, { -1, 0 }, { 0, -1 }, { 0, 1 },};#define _y first#define _x second#pragma endregion#pragma region 빠른 입출력#define FAST_IO() \{\ ios::sync_with_stdio(false);\ cin.tie(NULL); \ cout.tie(NULL); \}\#pragm..