Skip to content

Conversation

@caucsejunseo
Copy link
Collaborator

@caucsejunseo caucsejunseo commented Apr 30, 2025

๐Ÿ”— ๋ฌธ์ œ ๋งํฌ

๋“ฃ๋ณด์žก

์ฒ˜์Œ์—” ์ด์ค‘ํฌ๋ฌธ์œผ๋กœ ํ•˜๋‹ค๊ฐ€ ์‹œ๊ฐ„์ดˆ๊ณผ๊ฐ€ ๋– ์„œ ๋‹ค์‹œ ํ–ˆ์Šต๋‹ˆ๋‹ค. ์‹œ๊ฐ„ ์ดˆ๊ณผ๊ฐ€ ๋œฌ ์ฝ”๋“œ๋„ ์ฃผ์„์œผ๋กœ ๋‹ฌ์•„๋†จ์Šต๋‹ˆ๋‹ค.

โœ”๏ธ ์†Œ์š”๋œ ์‹œ๊ฐ„

2h

โœจ ์ˆ˜๋„ ์ฝ”๋“œ

image

๋ง์ด ๋“ฃ๋ณด์žก์ด์ง€ ๊ทธ๋ƒฅ A๊ทธ๋ฃน์—๋„ ์†ํ•˜๊ณ  B๊ทธ๋ฃน์—๋„ ์†ํ•œ ์‚ฌ๋žŒ์„ ์ฐพ๋Š” ๋ฌธ์ œ์ž…๋‹ˆ๋‹ค.

์ €๋Š” ๊ตฌ์กฐ์ฒด๊ฐ€ ์ต์ˆ™ํ•ด์„œ ๊ตฌ์กฐ์ฒด๋ฅผ ์‚ฌ์šฉํ•˜์˜€์Šต๋‹ˆ๋‹ค. A๊ทธ๋ฃน ๊ตฌ์กฐ์ฒด ํ•˜๋‚˜, B๊ทธ๋ฃน ๊ตฌ์กฐ์ฒดํ•˜๋‚˜ ๊ทธ๋ฆฌ๊ณ  ๊ณตํ†ต๋œ ๋ช…๋‹จ์„ ๋„ฃ์„ ๊ตฌ์กฐ์ฒด ํ•˜๋‚˜๋ฅผ ์„ ์–ธํ•ฉ๋‹ˆ๋‹ค.
ํ•œ ๋ฌธ์žฅ์”ฉ ์ž…๋ ฅ์„ ๋ฐ›๊ณ  ๊ฐœํ–‰๋ฌธ์ž๋ฅผ ์‚ญ์ œ.

๊ทธ ํ›„ A๊ทธ๋ฃน์„ ๋จผ์ € ์‚ฌ์ „ ์ˆœ์œผ๋กœ ์ •๋ ฌ์‹œ์ผœ์ค๋‹ˆ๋‹ค. ์ด๋Š” ์ด๋ถ„ํƒ์ƒ‰์„ ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•จ์ž…๋‹ˆ๋‹ค. ์ด๋ถ„ํƒ์ƒ‰์€ ์ •๋ ฌ๋œ ์ƒํƒœ์—์„œ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๊ธฐ ๋•Œ๋ฌธ!

๊ทธ ํ›„ B๊ทธ๋ฃน์— ์†ํ•ด์žˆ๋Š” ์‚ฌ๋žŒ๊ณผ ์ผ์น˜ํ•˜๋Š” ์‚ฌ๋žŒ์„ ์ •๋ ฌ๋œ A๊ทธ๋ฃน์—์„œ ์ด๋ถ„ํƒ์ƒ‰์„ ์ด์šฉํ•˜์—ฌ ์ฐพ์•„์ค๋‹ˆ๋‹ค.
๋ฌธ์ž์—ด๋„ ๊ฒฐ๊ตญ ์•„์Šคํ‚ค ์ฝ”๋“œ์ด๊ธฐ ๋•Œ๋ฌธ์— ์ •์ˆ˜๋กœ ์ƒ๊ฐํ•˜๋ฉด ๋ฉ๋‹ˆ๋‹ค.
์˜ˆ๋ฅผ ๋“ค์–ด A={1,2,4,5,6}, B={2, 4, 5} ์ด๋Ÿฐ ๋ฐฐ์—ด์—์„œ ๋จผ์ € 2๋ฅผ A์—์„œ ์ฐพ์•„๋ณด๊ณ  ์žˆ๋‹ค๋ฉด 1 ์—†๋‹ค๋ฉด NULL.
์ด๋•Œ 2๋ฅผ ์ฐพ๋Š” ๊ณผ์ •์—์„œ ์ด๋ถ„ํƒ์ƒ‰์„ ์ด์šฉํ•œ๋‹ค๋Š” ๋œป์ž…๋‹ˆ๋‹ค.

B๊ทธ๋ฃน์— ์žˆ๋Š” ์‚ฌ๋žŒ๊ณผ ์ผ์น˜ํ•˜๋Š” ์‚ฌ๋žŒ์ด A๊ทธ๋ฃน์— ์žˆ๋‹ค๋ฉด ์•ž์„œ ๋งŒ๋“  ์ •๋‹ต ๊ตฌ์กฐ์ฒด ๋ฐฐ์—ด์— ๋„ฃ์–ด์ฃผ๊ณ  ์ด ๋ฐฐ์—ด์„ ๋‹ค์‹œ ์‚ฌ์ „์ˆœ์œผ๋กœ ์ •๋ ฌํ•ด์ฃผ๋ฉด ๋!

์ˆ˜๋„ ์ฝ”๋“œ

์ž…๋ ฅ: ์ •์ˆ˜ N, M

// 1. N๋ช… ๋“ฃ๋„ ๋ชปํ•œ ์‚ฌ๋žŒ ์ด๋ฆ„ ์ž…๋ ฅ
๋ฐฐ์—ด nolisten[N]
๋ฐ˜๋ณต N๋ฒˆ:
    ์ด๋ฆ„ ์ž…๋ ฅ โ†’ nolisten[i]

// 2. M๋ช… ๋ณด๋„ ๋ชปํ•œ ์‚ฌ๋žŒ ์ด๋ฆ„ ์ž…๋ ฅ
๋ฐฐ์—ด nosee[M]
๋ฐ˜๋ณต M๋ฒˆ:
    ์ด๋ฆ„ ์ž…๋ ฅ โ†’ nosee[j]

// 3. ๋“ฃ๋„ ๋ชปํ•œ ์‚ฌ๋žŒ ๋ชฉ๋ก ์ •๋ ฌ (qsort)
์ •๋ ฌ(nolisten, ์ด๋ฆ„ ๊ธฐ์ค€)

// 4. ๋ณด๋„ ๋ชปํ•œ ์‚ฌ๋žŒ ์ค‘ ๋“ฃ๋„ ๋ชปํ•œ ์‚ฌ๋žŒ ์ฐพ๊ธฐ (์ด์ง„ ํƒ์ƒ‰)
๋ฐฐ์—ด nolistenandsee[MAX]
count = 0

๋ฐ˜๋ณต M๋ฒˆ:
    key โ† nosee[j]
    found โ† ์ด์ง„ํƒ์ƒ‰(key, nolisten)
    ๋งŒ์•ฝ ์ฐพ์•˜๋‹ค๋ฉด:
        nolistenandsee[count] โ† key
        count += 1

// 5. ๋“ฃ๋ณด์žก ๋ฆฌ์ŠคํŠธ ์ •๋ ฌ
์ •๋ ฌ(nolistenandsee[0 ~ count-1], ์ด๋ฆ„ ๊ธฐ์ค€)

// 6. ๊ฒฐ๊ณผ ์ถœ๋ ฅ
์ถœ๋ ฅ: count
์ถœ๋ ฅ: nolistenandsee[0 ~ count-1].name

๐Ÿ“š ์ƒˆ๋กญ๊ฒŒ ์•Œ๊ฒŒ๋œ ๋‚ด์šฉ

์ด๋ถ„ํƒ์ƒ‰์„ ๋ฌธ์ž๋กœ๋„ ๊ฐ€๋Šฅํ•œ๋‹ค๋Š” ๊ฒƒ์„ ์•Œ๊ฒŒ ๋˜์—ˆ๋‹ค. ๋ฌธ์ž๊ฐ€ ์‚ฌ์‹ค์ƒ ์•„์Šคํ‚ค๊ณ ๋“œ๋ผ์„œ ์‚ฌ์ „์‹ ์ •๋ฆฌ๋ฅผ ํ•  ๋•Œ ์ด๋ถ„ํƒ์ƒ‰์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.

Copy link
Contributor

@dohyeondol1 dohyeondol1 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ํ•ด์‹œ ๋ฌธ์ œ๋ผ๊ณ  ์ƒ๊ฐํ•˜๊ณ  ํ’€์—ˆ๋Š”๋ฐ ์ค€์„œ๋‹˜์€ ์ด๋ถ„ํƒ์ƒ‰์œผ๋กœ ํ‘ธ์…”์„œ ํฅ๋ฏธ๋กœ์› ์Šต๋‹ˆ๋‹ค ใ…Žใ…Ž

์ €๋Š” unordered_map์„ ์‚ฌ์šฉํ•ด์„œ
๋“ค์–ด๋ณธ ์  ์—†๋Š” ์‚ฌ๋žŒ์„ unordered_map์˜ key๋กœ, value๋ฅผ 0์œผ๋กœ ์„ค์ •ํ•˜์˜€์Šต๋‹ˆ๋‹ค.

๊ทธ๋‹ค์Œ, ๋ณธ ์  ์—†๋Š” ์‚ฌ๋žŒ์ด unordered_map์˜ key์ค‘์— ์žˆ๋Š”์ง€ ๊ฒ€์‚ฌํ•˜์˜€์Šต๋‹ˆ๋‹ค.
key๊ฐ€ ๋“ค์–ด๋ณธ ์  ์—†๋Š” ์‚ฌ๋žŒ์ด๋ฏ€๋กœ,
๋ณธ ์  ์—†๋Š” ์‚ฌ๋žŒ์ด key์ค‘์— ์žˆ๋‹ค๋ฉด ๊ทธ ์‚ฌ๋žŒ์ด ๋“ฃ๋ณด์žก..์ผ ๊ฑฐ์—์š”.

์กฐ๊ฑด์— ๋งž๋Š” ์‚ฌ๋žŒ์ด ์žˆ๋‹ค๋ฉด ์ •๋‹ต ๋ฐฐ์—ด์— ๋„ฃ์–ด ์ •๋ ฌ ํ›„ ์ถœ๋ ฅํ•˜๋Š” ๋ฐฉ์‹์œผ๋กœ ๋ฌธ์ œ๋ฅผ ํ•ด๊ฒฐํ•˜์˜€์Šต๋‹ˆ๋‹ค.

C++
#include <iostream>
#include <vector>
#include <algorithm>
#include <unordered_map>
using namespace std;
 
int main() {
    cin.tie(nullptr)->sync_with_stdio(false);
    
    int N, M; 
    cin >> N >> M;
    vector<string> answer;
    unordered_map<string, int> umap;
    
    string unheard = "";
    while(N--) {
        cin >> unheard;
        umap[unheard] = 0;
    }
    
    string unseen = "";
    while(M--) {
        cin >> unseen;
        if(umap.find(unseen) != umap.end()) answer.push_back(unseen);
    }
    
    sort(answer.begin(), answer.end());
    
    cout << answer.size() << "\n";
    for(string &ans : answer)
        cout << ans << "\n";
    
    return 0;
}

์ €๋„ ํ•ด์‹œ๋ฅผ ์•Œ๊ธฐ๋งŒ ์•Œ์•˜์ง€ ์ฝ”๋“œ๋กœ ๊ตฌํ˜„ํ•ด๋ณธ์ ์ด ์—†์–ด์„œ ์ด๋ฒˆ ๊ธฐํšŒ์— ๋ฐฐ์šฐ๊ณ  ์จ๋จน์–ด ๋ดค์Šต๋‹ˆ๋‹ค.
๋ง‰์ƒ ์ดํ•ดํ•˜๋ฉด ๊ทธ๋ ‡๊ฒŒ ์–ด๋ ต์ง€๋Š” ์•Š์€ ๊ฒƒ ๊ฐ™์•„์š”.
์ด์ œ ์—ด์‹ฌํžˆ ์œ ํ˜•์„ ์ฒดํ™”์‹œ์ผœ์•ผ์ฃ !

์ค€์„œ๋‹˜๋„ ํ•ด์‹œ๋กœ ํ•œ๋ฒˆ ํ’€์–ด๋ณด์‹œ๋ฉด ์ข‹์„ ๊ฒƒ ๊ฐ™์•„์š”.
์ด๋ถ„ ํƒ์ƒ‰์— ๋น„ํ•ด ์ดํ•ดํ–ˆ์„ ๋•Œ ๊ตฌํ˜„ํ•˜๊ธฐ๊ฐ€ ๋” ์‰ฌ์šธ๊ฑฐ๋ผ๊ณ  ์ƒ๊ฐํ•ฉ๋‹ˆ๋‹ค.
๋ฌผ๋ก  bsearch๋ผ๋Š” ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ ํ•จ์ˆ˜๋ฅผ ์‚ฌ์šฉํ•˜์‹  ๊ฒƒ ๊ฐ™์ง€๋งŒ,,

@froglike6
Copy link
Collaborator

์ €๋Š” ํŒŒ์ด์ฌ์˜ ์ง‘ํ•ฉ์„ ์ด์šฉํ•ด์„œ, ๋“ฃ๋„ ๋ชปํ•œ ์‚ฌ๋žŒ์˜ ์ง‘ํ•ฉ๊ณผ ๋ณด๋„ ๋ชปํ•œ ์‚ฌ๋žŒ์˜ ์ง‘ํ•ฉ์„ ๊ต์ง‘ํ•ฉํ•˜์—ฌ ์ •๋ ฌํ•˜๋Š” ๋ฐฉ๋ฒ•์œผ๋กœ ๋ฌธ์ œ๋ฅผ ํ’€์—ˆ์Šต๋‹ˆ๋‹ค. ๋ฌธ์ œ๋ฅผ ๋ณด๋‹ˆ ์ด๋ถ„ํƒ์ƒ‰์„ ์‚ฌ์šฉํ•  ์ƒ๊ฐ๋„ ๋ชปํ–ˆ๋Š”๋ฐ, ์ƒˆ๋กœ์šด ์ง€์‹์„ ์–ป์–ด๊ฐ‘๋‹ˆ๋‹ค ใ…Žใ…Ž

Python 3

import sys
input=sys.stdin.readline

n, m = map(int, input().split())
heard = set(input().rstrip() for _ in range(n))
seen = set(input().rstrip() for _ in range(m))

heardandseen = sorted(heard&seen)
print(len(heardandseen))
for i in heardandseen:
    print(i)

Copy link
Collaborator

@hadongun hadongun left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

์ €๋„ ์ค€์„œ๋‹˜์ฒ˜๋Ÿผ ์ด์ค‘ for๋ฌธ์„ ์“ฐ๋ ค๋‹ค๊ฐ€ ์‹œ๊ฐ„ ์ดˆ๊ณผ๋˜๋”๊ตฐ์š” ใ…Žใ…Ž
๊ทธ๋ž˜์„œ ์ด์ค‘ for๋ฌธ ๋Œ๋ฆฌ๊ธฐ ์ „์— ๊ฐ ๋“ฃ๋„๋ชปํ•œ ๋ฆฌ์ŠคํŠธ์™€ ๋ณด๋„๋ชปํ•œ ๋ฆฌ์ŠคํŠธ๋ฅผ ์ •๋ ฌํ•˜๊ณ  ๋น„๊ตํ•œ๋‹ค๋ฉด? ํ–ˆ์ง€๋งŒ ์—ฌ์ „ํžˆ ์‹œ๊ฐ„ ์ดˆ๊ณผ๊ฐ€ ๋œจ๋”๊ตฐ์š”.. ์ฐพ์•„๋ณด๋‹ˆ ํŒŒ์ด์ฌ์— set์ด๋ผ๋Š” ์ง‘ํ•ฉ ๊ฐ™์€ ์ž๋ฃŒํ˜•์ด ์žˆ๋”๊ตฐ์š”! ์ฒ˜์Œ ์•Œ๊ฒŒ๋˜์—ˆ๋„ค์šฅ

ํŒŒ์ดํŒŒ์ด์ฌ

import sys
N, M  = map(int, input().split())
fakecanthear = []
fakecantsee = []
canthearsee = []
for _ in range(N):
    fakecanthear.append(sys.stdin.readline().strip())
for _ in range(M):
    fakecantsee.append(sys.stdin.readline().strip())
canthear = set(fakecanthear)
cantsee = set(fakecantsee)
canthearsee = sorted(canthear & cantsee)

canthearsee.sort()
print(len(canthearsee))
for ch in canthearsee:
    print(ch)
    

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants