πŸ“š
TIL
  • README
  • Git
    • Basic
    • Remote Repository
    • Log & Diff
    • Rebase&Cherri-Pick
    • git-flow
  • DevOps
    • Monolithic vs MSA
    • Jenkins μ‹œμž‘ν•˜κΈ°
    • Airflow μ‹œμž‘ν•˜κΈ°
    • Airflow μ‹œμž‘ν•˜κΈ°
    • Build Tools
      • maven
  • 개발 방법둠
    • TDD
  • Spring
    • IoC
    • Is Spring Bean Thread-Safe?
    • Spring Singleton
    • Component Scan
    • Spring Annotation
    • 의쑴 관계 μ£Όμž…(DI)
    • Lombok ν™œμš©ν•˜κΈ°
    • Bean 생λͺ…주기와 콜백
    • Bean Scope
    • AOP(1) - AOPλž€
    • AOP(2) - Aop Proxy
    • AOP(3) - Dynamic Proxy
    • AOP(4) - AspectJ
    • POJO
    • Spring μ„œλΉ„μŠ€ ꡬ쑰
    • Transaction
    • JPAλž€?
    • JPA Entity
    • Spring Data JPA
    • Spring Data Specification
    • Model Mapping
    • Cache
    • restTemplate
    • YAML 파일 μ„€μ •
    • Spring Boot
      • H2 DB μ„€μ •
      • 닀쀑 λ°μ΄ν„°λ² μ΄μŠ€ μ„€μ •
      • Mybatis μ—°λ™ν•˜κΈ°
    • Spring Batch
      • Batch μ‹œμž‘ν•΄λ³΄κΈ°
      • Batch Job Flow
      • Job
      • Step
      • Batch Scope & Job Parameter
      • JobRepository와 λ©”νƒ€ν…Œμ΄λΈ”
      • Chunk μ§€ν–₯ ν”„λ‘œκ·Έλž˜λ°
      • ItemReader
      • ItemProcessor
      • ItemWriter
      • Batch Schedular
      • Job별 Beanλ“±λ‘ν•˜κΈ°
      • Batch κ΅¬ν˜„μ‹œ λ°œμƒν•œ 였λ₯˜ 정리
      • Spring Batch Scaling
        • Multithread Jobκ΅¬ν˜„μ‹œ μ΄μŠˆμ‚¬ν•­
    • Spring test
      • Junit5
        • ν…ŒμŠ€νŠΈ 이름 ν‘œκΈ°
        • ν…ŒμŠ€νŠΈ κ·Έλ£Ή μ‚¬μ΄μ˜ 관계
        • νƒœκ·Έμ™€ 필터링
        • 동적 ν…ŒμŠ€νŠΈ
        • ν…ŒμŠ€νŠΈ LifeCycle
        • ν…ŒμŠ€νŠΈ λ©”μ„œλ“œ
        • ν…ŒμŠ€νŠΈ μˆœμ„œ
        • AssertJ
        • ν…ŒμŠ€νŠΈ 병렬 μ‹€ν–‰
        • AssertJ
        • Mock
      • Spring Boot Test DB 뢄리
      • Spring Batch Test
  • Web Application
    • Web Server & WAS
    • κ΄€λ ¨ κ°œλ… - HTTP API, HTML, CSR, SSR
    • Servlet
    • JSP
    • Cookie And Session
    • μ˜ˆμ™ΈνŽ˜μ΄μ§€
    • Java Bean
    • JDBC
    • Connection Pool
    • 파일 μ—…λ‘œλ“œ
    • Expression Language
    • JSTL
    • FrontControllerνŒ¨ν„΄ Command νŒ¨ν„΄
    • Forwarding
    • MVC
    • νšŒμ›κ°€μž…μ˜ˆμ œ
    • μ°Έκ³ 
      • κ°œλ°œν™˜κ²½μ„€μ •
  • Java+
    • SOAP/WSDL vs REST
    • WSDL을 JAVA둜 λ³€ν™˜ν•˜κΈ°
    • SOAP 톡신 OPEN API둜 κ°œλ°œν•΄λ³΄κΈ°
  • Java
    • Basic
      • λ³€μˆ˜μ™€ νƒ€μž…
      • μ—°μ‚°μž
      • 쑰건문과 반볡문
      • μ°Έμ‘° νƒ€μž…
      • 클래슀
      • 상속(Inheritance)
      • μΈν„°νŽ˜μ΄μŠ€(Interface)
      • 쀑첩 ν΄λž˜μŠ€μ™€ 쀑첩 μΈν„°νŽ˜μ΄μŠ€
      • μ˜ˆμ™Έ 처리
      • API - Object, System, Class, Math, Wrapper
      • API - String, StringBuffer, StringBuilder
      • Thread
      • Generic
      • Lambda
      • Collection - List, Set
      • Collection - Map
      • Collection - Tree
      • Collection - Stack, Queue
      • Stream
      • Reflection
      • μ •κ·œν‘œν˜„μ‹
      • GUI
      • UML
      • Serializable
    • Advanced
      • OutOfMemoryError
      • AutoValue
      • meta-annotation
        • @Retention
        • @Target
        • @Repeatable
    • Effective Java 3/E
      • ITEM 1: Static Factory Method(정적 λ©”μ†Œλ“œ)
      • ITEM 2: Builder Pattern
      • ITEM 3: Singleton
      • ITEM 4: Private Constructor
      • ITEM 5: Dependency Injection
      • ITEM 6: Avoid Unnecessary Object
      • ITEM 7: Eliminate Object Reference
      • ITEM 8: Avoid finalizer and cleaner
      • ITEM 9: try-with-resources
      • ITEM 10: The gerneral contract when overriding equlas
      • ITEM 11: Overriding hashCode
      • ITEM 12: overriding toString
      • ITEM 13: overriding clone judiciously
      • ITEM 14: Consider implementing comparable
      • ITEM 15: ν΄λž˜μŠ€μ™€ λ©€λ²„μ˜ 접근을 μ΅œμ†Œν™”ν•΄λΌ
      • ITEM 16: Use Accessor methods
      • ITEM 17: λ³€κ²½ κ°€λŠ₯성을 μ΅œμ†Œν™”ν•΄λΌ(λΆˆλ³€ 클래슀)
      • ITEM 18: 상속보단 μ»΄ν¬μ§€μ…˜μ„ μ‚¬μš©ν•΄λΌ
      • ITEM 19: 상속을 κ³ λ €ν•΄ μ„€κ³„ν•˜κ³  λ¬Έμ„œν™”ν•΄λΌ
      • ITEM 20: 좔상 ν΄λž˜μŠ€λ³΄λ‹€ μΈν„°νŽ˜μ΄μŠ€λ₯Ό μš°μ„ ν•˜λΌ
      • ITEM 21: μΈν„°νŽ˜μ΄μŠ€λŠ” κ΅¬ν˜„ν•˜λŠ” μͺ½μ„ 생각해 섀계해라.
      • ITEM 22: μΈν„°νŽ˜μ΄μŠ€λŠ” νƒ€μž…μ„ μ •μ˜ν•˜λŠ” μš©λ„λ‘œλ§Œ μ‚¬μš©ν•΄λΌ
      • ITEM 23: νƒœκ·Έ 달린 ν΄λž˜μŠ€λ³΄λ‹€ 클래슀 계측ꡬ쑰λ₯Ό ν™œμš©ν•΄λΌ
      • ITEM 24: 멀버 ν΄λž˜μŠ€λŠ” λ˜λ„λ‘ static으둜 κ΅¬ν˜„ν•΄λΌ
      • ITEM 25: ν†±λ ˆλ²¨ ν΄λž˜μŠ€λŠ” ν•œ νŒŒμΌμ— ν•˜λ‚˜λ§Œ 생성해라.
      • ITEM 26: Raw type은 μ‚¬μš©ν•˜μ§€ 마라
      • ITEM 27: 비검사 κ²½κ³ λ₯Ό μ œκ±°ν•΄λΌ
      • ITEM 28: λ°°μ—΄λ³΄λ‹€λŠ” 리슀트λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 29: 이왕이면 μ œλ„€λ¦­ νƒ€μž…μœΌλ‘œ λ§Œλ“€μ–΄λΌ
      • ITEM 30: 이왕이면 μ œλ„€λ¦­ λ©”μ„œλ“œλ‘œ λ§Œλ“€μ–΄λΌ
      • ITEM 31 : ν•œμ •μ  μ™€μΌλ“œμΉ΄λ“œλ₯Ό μ‚¬μš©ν•΄ API μœ μ—°μ„±μ„ 높여라
      • ITEM 32: μ œλ„€λ¦­κ³Ό κ°€λ³€μΈμˆ˜λ₯Ό ν•¨κ»˜ μ“Έ λ•ŒλŠ” 신쀑해라
      • ITEM 33: νƒ€μž… μ•ˆμ „ 이쒅 μ»¨ν…Œμ΄λ„ˆλ₯Ό 고렀해라
      • ITEM 34: int μƒμˆ˜ λŒ€μ‹  μ—΄κ±° νƒ€μž…μ„ μ‚¬μš©ν•΄λΌ
      • ITEM 35: ordinal λ©”μ„œλ“œ λŒ€μ‹  μΈμŠ€ν„΄μŠ€ ν•„λ“œλ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 36: λΉ„νŠΈ ν•„λ“œ λŒ€μ‹  EnumSet을 μ‚¬μš©ν•΄λΌ
      • ITEM 37: ordinal 인덱싱 λŒ€μ‹  EnumMap을 μ‚¬μš©ν•΄λΌ
      • TEM 38 : ν™•μž₯ν•  수 μžˆλŠ” μ—΄κ±°νƒ€μž…μ΄ ν•„μš”ν•˜λ©΄ μΈν„°νŽ˜μ΄μŠ€λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 39: λͺ…λͺ… νŒ¨ν„΄λ³΄λ‹€ μ• λ„ˆν…Œμ΄μ…˜μ„ μ‚¬μš©ν•΄λΌ
      • ITEM 40: @Override μ–΄λ…Έν…Œμ΄μ…˜μ„ μΌκ΄€λ˜κ²Œ μ‚¬μš©ν•΄λΌ
      • ITEM 41: μ •μ˜ν•˜λ €λŠ” 것이 νƒ€μž…μ΄λΌλ©΄ 마컀 μΈν„°νŽ˜μ΄μŠ€λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 42: 읡λͺ… ν΄λž˜μŠ€λ³΄λ‹€λŠ” λžŒλ‹€λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 43: λžŒλ‹€λ³΄λ‹€λŠ” λ©”μ„œλ“œ μ°Έμ‘°λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 44: ν‘œμ€€ ν•¨μˆ˜ν˜• μΈν„°νŽ˜μ΄μŠ€λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 45: μŠ€νŠΈλ¦Όμ€ μ£Όμ˜ν•΄μ„œ μ‚¬μš©ν•΄λΌ
      • ITEM 46: μŠ€νŠΈλ¦Όμ—μ„œ λΆ€μž‘μš© μ—†λŠ” ν•¨μˆ˜λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 47: λ°˜ν™˜ νƒ€μž…μœΌλ‘œλŠ” μŠ€νŠΈλ¦Όλ³΄λ‹€ μ»¬λ ‰μ…˜μ΄ λ‚«λ‹€.
      • ITEM 48: 슀트림 λ³‘λ ¬ν™”λŠ” μ£Όμ˜ν•΄μ„œ μ‚¬μš©ν•΄λΌ
      • ITEM 49: λ§€κ°œλ³€μˆ˜κ°€ μœ νš¨ν•œμ§€ 검사해라
      • ITEM 50: μ μ‹œμ— 방어적 볡사본을 λ§Œλ“€μ–΄λΌ
      • ITEM 51: λ©”μ„œλ“œ μ‹œκ·Έλ‹ˆμ²˜λ₯Ό μ‹ μ€‘νžˆ 섀계해라
      • ITEM 52: λ‹€μ€‘μ •μ˜λŠ” μ‹ μ€‘νžˆ μ‚¬μš©ν•΄λΌ
      • ITEM 53: κ°€λ³€μΈμˆ˜λŠ” μ‹ μ€‘νžˆ μ‚¬μš©ν•΄λΌ
      • ITEM 54: null이 μ•„λ‹Œ, 빈 μ»¬λ ‰μ…˜μ΄λ‚˜ 배열을 λ°˜ν™˜ν•΄λΌ
      • ITEM 55: Optional λ°˜ν™˜μ€ μ‹ μ€‘ν•˜κ²Œ 해라
      • ITEM 56: 곡개된 API μš”μ†Œμ—λŠ” 항상 주석을 μž‘μ„±ν•΄λΌ
      • ITEM 57: μ§€μ—­λ³€μˆ˜μ˜ λ²”μœ„λ₯Ό μ΅œμ†Œν™”ν•΄λΌ
      • ITEM 58: 전톡적인 for λ¬Έλ³΄λ‹€λŠ” for-each문을 μ‚¬μš©ν•΄λΌ
      • ITEM 59: 라이브러리λ₯Ό 읡히고 μ‚¬μš©ν•΄λΌ
      • ITEM 60: μ •ν™•ν•œ 닡이 ν•„μš”ν•˜λ‹€λ©΄ float와 double은 피해라
      • ITEM 61: λ°•μ‹±λœ κΈ°λ³Έ νƒ€μž…λ³΄λ‹€λŠ” κΈ°λ³Έ νƒ€μž…μ„ μ‚¬μš©ν•΄λΌ
      • ITEM 62: λ‹€λ₯Έ νƒ€μž…μ΄ μ μ ˆν•˜λ‹€λ©΄ λ¬Έμžμ—΄ μ‚¬μš©μ„ 피해라
      • ITEM 63: λ¬Έμžμ—΄ 연결은 λŠλ¦¬λ‹ˆ μ£Όμ˜ν•΄λΌ
      • ITEM 64: κ°μ²΄λŠ” μΈν„°νŽ˜μ΄μŠ€λ₯Ό μ‚¬μš©ν•΄ 참쑰해라
      • ITEM 65: λ¦¬ν”Œλ ‰μ…˜λ³΄λ‹€λŠ” μΈν„°νŽ˜μ΄μŠ€λ₯Ό μ‚¬μš©ν•΄λΌ
      • ITEM 66: λ„€μ΄ν‹°λΈŒ λ©”μ„œλ“œλŠ” μ‹ μ€‘νžˆ μ‚¬μš©ν•΄λΌ
      • ITEM 67: μ΅œμ ν™”λŠ” μ‹ μ€‘νžˆ 해라
      • ITEM 68: 일반적으둜 ν†΅μš©λ˜λŠ” λͺ…λͺ… κ·œμΉ™μ„ 따라라
    • 객체지ν–₯ 섀계 원칙(SOLID)
    • λ””μžμΈνŒ¨ν„΄
      • Strategy Pattern
      • Template Method Pattern
      • Factory Method Pattern
      • Singleton
      • Delegation
      • Proxy
      • Adapter Pattern
    • μ‹€μŠ΅
      • μΈν„°νŽ˜μ΄μŠ€ μ‹€μŠ΅ - Vehicle
      • μΈν„°νŽ˜μ΄μŠ€ μ‹€μŠ΅ - Remote
      • GUI μ‹€μŠ΅ - Calculator
      • GUI μ‹€μŠ΅ - button
      • GUI μ‹€μŠ΅ - lotto
      • Thread μ‹€μŠ΅ - μ’Œμ„μ˜ˆμ•½, 메세지보내기
    • Jar vs War
  • λ°μ΄ν„°λ² μ΄μŠ€
    • KEY
    • Index
    • Transaction
    • Trigger
    • Procedure / Function
    • Package
    • λ°μ΄ν„°λ² μ΄μŠ€ 배움터
      • λ°μ΄ν„°λ² μ΄μŠ€ μ‹œμŠ€ν…œ
      • 관계데이터 λͺ¨λΈ
      • κ΄€κ³„λŒ€μˆ˜μ™€ SQL
    • MySQL
      • Databaseλž€
      • MySQL μ‹œμž‘ν•˜κΈ°
      • MySQL Database
      • MySQL Table
      • CRUD
      • κ΄€κ³„ν˜• λ°μ΄ν„°λ² μ΄μŠ€
      • Server와 Client
    • PostgreSQL
    • NoSQL
      • Install Cassandra on mac
      • Cassandraλž€?
      • NiFiλž€
  • Algorithm
    • String
    • Recursion
    • Dynamic Programming
    • Array, Struct, Pointer
    • Math
    • Sort
    • List
    • Stack
    • Queue
    • Graph
    • Tree
    • Maze
    • AVL
    • μ΄μ§„νƒμƒ‰νŠΈλ¦¬(Binary Search Tree)
    • DFS와 BFS
    • λ‹€μ΅μŠ€νŠΈλΌ μ•Œκ³ λ¦¬μ¦˜(Dijkstra's Algorithm)
    • Red-Black 트리
    • A* μ•Œκ³ λ¦¬μ¦˜
    • Heap
    • Huffman Coding
    • Priority Queue
    • Bellman-Ford μ•Œκ³ λ¦¬μ¦˜
    • C++
      • Class
      • STL
        • STL pair
        • STL Container - Associate Container
        • STL Container - Sequence Container
        • STL Container - Container Adapter
  • JavaScript
    • JABASCRIPT BASIC
    • Shallow Copy vs Deep Copy
    • OBJECT MODEL
    • NODE
    • 동기 처리 vs 비동기 처리
    • AJAX
    • CALLBACK
    • PROMISE
    • DEFERRER
    • UNDERSCORE
    • WEBPACK
    • SCOPE
    • EXECUTION CONTEXT
    • Image Object
    • BFCacheλž€?
    • history.scrollRestoration
    • Intersection Observer
    • JWT - JSON Web Token
    • HTML vs JSON
  • Vue.js
    • ν™˜κ²½μ„€μ •
    • Vue.jsλž€?
    • Vue Instance
    • Vue Component
    • Vue Router
    • HTTP 톡신
    • Template
    • Single File Component
    • Vue Animation
    • Vuex
    • Djnago와 μ—°λ™ν•˜κΈ°
  • Backbone.js
    • Model
    • Collection
    • Sync
    • view
  • Node.js
    • Doit! - λ…Έλ“œλ‘œ λ§Œλ“€ 수 μžˆλŠ” λŒ€ν‘œμ μΈ μ„œλ²„μ™€ μš©λ„
    • Doit! - λ…Έλ“œμ— λŒ€ν•΄ μ•Œμ•„λ³΄κ³  개발 도ꡬ μ„€μΉ˜ν•˜κΈ°
    • Doit! - λ…Έλ“œ κ°„λ‹¨ν•˜κ²Œ μ‚΄νŽ΄λ³΄κΈ°
    • Doit! - λ…Έλ“œμ˜ μžλ°”μŠ€ν¬λ¦½νŠΈμ™€ μΉœν•΄μ§€κΈ°
    • Doit! - λ…Έλ“œμ˜ κΈ°λ³Έ κΈ°λŠ₯ μ•Œμ•„λ³΄κΈ°
    • Doit! - μ›Ή μ„œλ²„ λ§Œλ“€κΈ°
    • Doit! - λ°μ΄ν„°λ² μ΄μŠ€ μ‚¬μš©ν•˜κΈ°
    • Doit! - μ΅μŠ€ν”„λ ˆμŠ€ ν”„λ‘œμ νŠΈλ₯Ό λͺ¨λ“ˆν™”ν•˜κΈ°
    • Doit! - λ·° ν…œν”Œλ¦Ώ μ μš©ν•˜κΈ°
    • Doit! - 패슀포트둜 μ‚¬μš©μž μΈμ¦ν•˜κΈ°
    • Doit! - μ±„νŒ…μ„œλ²„ λ§Œλ“€κΈ°
    • Doit! - JSON-RPC μ„œλ²„ λ§Œλ“€κΈ°
  • Python
    • Warning-Could not import the lzma module
    • Pandas
      • Pandas 자료ꡬ쑰
      • Pandas 데이터 μž…μΆœλ ₯
      • DataFrame Data μ‚΄νŽ΄λ³΄κΈ°
      • μ‹œκ°ν™” 도ꡬ - Matplotlib
  • ML
    • μΆ”μ²œ μ‹œμŠ€ν…œ
      • Collaborative Filtering
      • Matrix Factorization
  • Django
    • Basic
      • ν™˜κ²½μ„€μ •
      • About Django
      • Start Django Project
      • Secret Key κ΄€λ¦¬ν•˜κΈ°
      • Settings λΆ„λ¦¬ν•˜κΈ°
      • Django App
      • Django View & URL (1)
      • Django Model
        • MySQL 연동
      • Django Admin
      • Django View & URL (2)
      • Django Template
      • Django Template & View & URL
      • Django Static
      • Django form
    • Advanced
      • Django Generic View
      • Django Automated Testing
      • Django Extenstion Template
      • Django Model Package
      • Django OpenSSL setting
    • REST framework
      • Rest API
      • Serializers
      • ViewSet
    • Error
      • ν™˜κ²½μ„€μ • zlib 였λ₯˜λ°œμƒ
      • ModuleNotFoundError
    • νŒ¨ν‚€μ§€
      • django-debug-toolbar
    • Vue.js μ—°λ™ν•˜κΈ°
  • Ruby
    • variable & input/output
    • 쑰건문
    • 반볡문
    • Array & Hash
    • Method
    • Proc&Lamda
    • Class
  • Ruby on Rails
    • Scaffolding
    • Controller
    • Model
    • Model-M:N relation
    • Model Validation
    • 멋사 10μ£Όμ°¨ μˆ˜μ—…(Tip)
  • HTML/CSS
    • Udacity - Intro to HTML/CSS
    • Udacity - Responsive Web Design
    • Udacity - Responsive Images
    • HTML Basic
    • CSS Basic
    • HTML5 Sementic Tag
    • HTML ν…μŠ€νŠΈ κ΄€λ ¨ νƒœκ·Έλ“€
    • HTML5 λ©€ν‹°λ―Έλ””μ–΄
    • HTML 폼 κ΄€λ ¨ νƒœκ·Έλ“€
    • ν…μŠ€νŠΈ κ΄€λ ¨ μŠ€νƒ€μΌ
    • 색상과 배경을 μœ„ν•œ μŠ€νƒ€μΌ
    • λ ˆμ΄μ•„μ›ƒμ„ μœ„ν•œ μŠ€νƒ€μΌ
    • CSS 포지셔닝
    • λ‹€μž¬λ‹€λŠ₯ν•œ CSS3 μ„ νƒμž
    • CSS와 μ• λ‹ˆλ©”μ΄μ…˜
    • λ°˜μ‘ν˜• μ›Ήμ΄λž€?
  • OS(운영체제)
    • Linux
      • Daemon
      • Cron
      • ν”„λ‘œμ„ΈμŠ€ κ΄€λ ¨ λͺ…λ Ήμ–΄
      • ν…μŠ€νŠΈ 파일 λͺ…λ Ήμ–΄
  • Network
    • λ„€νŠΈμ›Œν¬ κΈ°λ³Έ κ°œλ…
    • λ„€νŠΈμ›Œν¬ κΈ°λ³Έ κ·œμΉ™
    • 물리 계측
    • 데이터 링크 계측
    • λ„€νŠΈμ›Œν¬ 계측
    • 전솑 계측
    • μ‘μš© 계측
    • λ„€νŠΈμ›Œν¬ 전체 흐름
    • 무선 랜
  • IT 기타지식
    • NASλž€
Powered by GitBook
On this page
  • λ‚˜λ¨Έμ§€μ—°μ‚°
  • μ΅œλŒ€κ³΅μ•½μˆ˜(Gretest Common Divisor)
  • μ΅œμ†Œκ³΅λ°°μˆ˜(Least Common Multiple)
  • 진법 λ³€ν™˜
  • 10 to N
  • B to 10
  • 2 to 8
  • 8 to 2
  • 8 to -2
  • A to B
  • μ†Œμˆ˜
  • κ΅¬ν˜„ 방법
  • μ†Œμˆ˜ μ°ΎκΈ°
  • μ—λΌν† μŠ€ν…Œλ„€μŠ€μ˜ 체
  • μ†ŒμΈμˆ˜λΆ„ν•΄
  • νŒ©ν† λ¦¬μ–Ό
  • νŒ©ν† λ¦¬μ–Ό 0의 개수
  • μ‘°ν•© 0의 개수

Was this helpful?

  1. Algorithm

Math

μˆ˜ν•™κ³Ό κ΄€λ ¨λœ μ•Œκ³ λ¦¬μ¦˜ 문제λ₯Ό ν’€μ–΄λ³Ό 것이닀.

λ‚˜λ¨Έμ§€μ—°μ‚°

문제 쀑 λ‚˜λ¨Έμ§€λ₯Ό κ΅¬ν•˜λΌλŠ” λ¬Έμ œκ°€ 있으면 닡을 λ‹€ κ΅¬ν•œν›„μ— κ΅¬ν•˜λ©΄ λ²”μœ„λ₯Ό μ΄ˆκ³Όν•  수 μžˆκΈ°λ•Œλ¬Έμ— 쀑간에 ν•΄μ€˜μ•Όν•œλ‹€.

(A+B)%C = ((A%C)+(B%C))%C

ex) A = q1*c + r1, B = q2*c + r2
A+B = (q1+q2)*c + (r1+r2)
(A+B)%c = (r1+r2)%c
A%c = r1, B%c = r2
  • κ³±ν•˜κΈ°μ˜ κ²½μš°μ—λ„ μ„±λ¦½ν•œλ‹€.

  • ν•˜μ§€λ§Œ λ‚˜λˆ„κΈ°μ˜ κ²½μš°μ—λŠ” μ„±λ¦½ν•˜μ§€μ•ŠλŠ”λ‹€.(Modular Inverseλ₯Ό κ΅¬ν•΄μ•Όν•œλ‹€.)

  • λΊ„μ…ˆμ˜ 경우 λ¨Όμ € modλ₯Ό ν•œ κ²°κ³Όκ°€ μŒμˆ˜κ°€ λ‚˜μ˜¬ 수 μžˆκΈ°λ•Œλ¬Έμ— (A-B)%M = ((A%M)-(B%M)+M)%M을 ν•΄μ€˜μ•Όν•œλ‹€.

#include <iostream>
using namespace std;

int main(){
    int a,b,c;
    scanf("%d %d %d",&a,&b,&c);
    // 첫째 쀄에 (A+B)%C, λ‘˜μ§Έ 쀄에 (A%C + B%C)%C, μ…‹μ§Έ 쀄에 (AΓ—B)%C, λ„·μ§Έ 쀄에 (A%C Γ— B%C)%Cλ₯Ό 좜λ ₯ν•œλ‹€.
    printf("%d\n%d\n%d\n%d",(a+b)%c,(a%c+b%c)%c,(a*b)%c,(a%c*b%c)%c);
}

μ΅œλŒ€κ³΅μ•½μˆ˜(Gretest Common Divisor)

두 수 A와 B의 μ΅œλŒ€κ³΅μ•½μˆ˜ GλŠ” A와 B의 κ³΅ν†΅λœ μ•½μˆ˜ μ€‘μ—μ„œ κ°€μž₯ 큰 μ •μˆ˜μ΄λ‹€. μ΄λ•Œ μ΅œλŒ€κ³΅μ•½μˆ˜κ°€ 1인 두 수λ₯Ό μ„œλ‘œμ†Œ(Coprime)이라고 ν•œλ‹€.

  1. 2λΆ€ν„° min(A,B)κΉŒμ§€ λͺ¨λ“  μ •μˆ˜λ‘œ λ‚˜λˆ„μ–΄λ³΄λŠ” 방법

  2. μœ ν΄λ¦¬λ“œ μ•Œκ³ λ¦¬μ¦˜(aλ₯Ό b둜 λ‚˜λˆˆ λ‚˜λ¨Έμ§€λ₯Ό r이라 ν–ˆμ„ λ•Œ, GCD(a,b)=GCD(b,r), r=0이면 κ·Έ λ•Œ bκ°€ μ΅œλŒ€κ³΅μ•½μˆ˜μ΄λ‹€.)

#include <iostream>
using namespace std;

//2. μœ ν΄λ¦¬λ“œ μ•Œκ³ λ¦¬μ¦˜ μž¬κ·€
int gcd(int a, int b){
    if(b==0){
        return a;
    }else{
        return gcd(b,a%b);
    }
}
//3. μœ ν΄λ¦¬λ“œ μ•Œκ³ λ¦¬μ¦˜ λΉ„μž¬κ·€
int gcd2(int a,int b){
    while(b!=0){
        int r=a%b;
        a=b;
        b=r;
    }
    return a;
}
int main(){
    int a,b,g;
    scanf("%d %d",&a,&b);
    g=1;
    //1. λͺ¨λ“  μ •μˆ˜
    for(int i=2;i<=min(a,b);i++){
        if(a%i==0 && b%i==0){
            g=i;
        }
    }
}

a<b인 κ²½μš°μ—”λŠ a%b=aμ΄λ―€λ‘œ μžλ™μœΌλ‘œ a와 bκ°€ λ°”λ€Œκ²Œ λœλ‹€. κ·ΈλŸ¬λ―€λ‘œ λ”°λ‘œ λŒ€μ†Œκ΄€κ³„λ₯Ό 비ꡐ해쀄 ν•„μš”κ°€ μ—†λ‹€.

  • μ„Έ κ°œμ΄μƒμ˜ μ΅œλŒ€κ³΅μ•½μˆ˜λŠ” GCD(a,b,c)=GCD(GCD(a,b),c)와 같은 μ‹μœΌλ‘œ κ³„μ†ν•΄μ„œ ꡬ할 수 μžˆλ‹€.

μ΅œμ†Œκ³΅λ°°μˆ˜(Least Common Multiple)

두 수의 κ³΅ν†΅λœ 배수 μ€‘μ—μ„œ κ°€μž₯ μž‘μ€ μ •μˆ˜μ΄λ‹€. μ΅œμ†Œκ³΅λ°°μˆ˜λŠ” μ΅œλŒ€κ³΅μ•½μˆ˜λ₯Ό μ΄μš©ν•΄μ„œ ꡬ할 수 μžˆλ‹€. 이 λ•Œ, μ΅œμ†Œκ³΅λ°°μˆ˜λŠ” 두 μˆ˜λ³΄λ‹€ 큰 μˆ˜μ΄λ―€λ‘œ λ²”μœ„λ₯Ό 잘 ν™•μΈν•΄μ„œ κ΅¬ν•΄μ•Όν•œλ‹€.

  • μ΅œλŒ€κ³΅μ•½μˆ˜ * μ΅œμ†Œκ³΅λ°°μˆ˜ = A*B이닀.

  • 즉, μ΅œμ†Œκ³΅λ°°μˆ˜ = (A*B)/μ΅œλŒ€κ³΅μ•½μˆ˜μ΄λ‹€.

#include <iostream>
using namespace std;

int gcd(int a, int b){
    if(b==0)return a;
    else{
        return gcd(b,a%b);
    }
}
int main(){
    int a,b,g,l;
    scanf("%d %d",&a,&b); //이 λ‘˜μ€ 10,000μ΄ν•˜μ˜ μžμ—°μˆ˜μ΄λ©° 사이에 ν•œ 칸의 곡백이 μ£Όμ–΄μ§„λ‹€.

    g=gcd(a,b); //μ΅œλŒ€κ³΅μ•½μˆ˜
    l=(a*b)/g; //μ΅œμ†Œκ³΅λ°°μˆ˜
    printf("%d\n%d",g,l);
}
#include <iostream>
using namespace std;

int gcd(int a, int b){
    if(b==0)return a;
    else{
        return gcd(b,a%b);
    }
}
int main(){
    int a,b,g,l,t;
    scanf("%d",&t);
    while(t--){
        scanf("%d %d",&a,&b); //이 λ‘˜μ€ 10,000μ΄ν•˜μ˜ μžμ—°μˆ˜μ΄λ©° 사이에 ν•œ 칸의 곡백이 μ£Όμ–΄μ§„λ‹€.

        g=gcd(a,b);
        l=(a*b)/g;
        printf("%d\n",l);
    }
}
//μ–‘μ˜ μ •μˆ˜ nκ°œκ°€ μ£Όμ–΄μ‘Œμ„ λ•Œ, κ°€λŠ₯ν•œ λͺ¨λ“  쌍의 GCD의 합을 κ΅¬ν•˜λŠ” ν”„λ‘œκ·Έλž¨μ„ μž‘μ„±ν•˜μ‹œμ˜€.
#include <iostream>
using namespace std;

int gcd(int a, int b){
    if(b==0)return a;
    else return gcd(b,a%b);
}
int main(){
    int t;
    scanf("%d",&t);
    while(t--){
        int n;
        int num[101]={0};
        scanf("%d",&n);

        for(int i=0;i<n;i++)scanf("%d",&num[i]);
        long long int sum=0;
        for(int i=0;i<n-1;i++){
            for(int j=i+1;j<n;j++){
                sum+=gcd(num[i],num[j]);
            }
        }
        printf("%lld\n",sum);
    }
}

진법 λ³€ν™˜

10진법 수 N을 Bμ§„λ²•μœΌλ‘œ λ°”κΎΈλ €λ©΄ N이 0이 λ λ•ŒκΉŒμ§€ λ‚˜λ¨Έμ§€λ₯Ό κ³„μ†ν•΄μ„œ κ΅¬ν•˜λ©΄λœλ‹€.

ex)11을 3μ§„λ²•μœΌλ‘œ λ°”κΎΈλŠ” 방법
11/3=3...2
3/3=1...0
1/3=0...1

μ •λ‹΅ 102

10 to N

  • 10진법 수 N이 μ£Όμ–΄μ§„λ‹€. 이 수λ₯Ό Bμ§„λ²•μœΌλ‘œ λ°”κΏ” 좜λ ₯ν•˜λŠ” ν”„λ‘œκ·Έλž¨μ„ μž‘μ„±ν•˜μ‹œμ˜€.

  • A: 10, B: 11, ..., F: 16, ..., Y: 34, Z: 35

#include <iostream>
#include <string>
#include <algorithm>
using namespace std;

int main(){
    int n,b;
    scanf("%d %d",&n, &b);
    string ans="";
    while(n>0){
        int r=n%b;
        if(r<10){
            ans+=(char)(r+'0');
        }else{
            ans+=(char)(r-10+'A');
        }
        n/=b;
    }
    reverse(ans.begin(),ans.end());
    cout << ans;
}

B to 10

  • B진법 수 N이 μ£Όμ–΄μ§„λ‹€. 이 수λ₯Ό 10μ§„λ²•μœΌλ‘œ λ°”κΏ” 좜λ ₯ν•˜λŠ” ν”„λ‘œκ·Έλž¨μ„ μž‘μ„±ν•˜μ‹œμ˜€.

  • A: 10, B: 11, ..., F: 16, ..., Y: 34, Z: 35

#include <iostream>
#include <string>
using namespace std;


int main(){
    int ans=0;
    int b;
    string s;
    cin >> s >> b;
    for(int i=0;i<s.size();i++){
        if('0'<=s[i]&&s[i]<='9'){
            ans=ans*b+s[i]-'0';
        }else{
            ans=ans*b+s[i]-'A'+10;
        }
    }
    printf("%d",ans);
}

2 to 8

  • 2μ§„μˆ˜κ°€ μ£Όμ–΄μ‘Œμ„ λ•Œ, 8μ§„μˆ˜λ‘œ λ³€ν™˜ν•˜λŠ” ν”„λ‘œκ·Έλž¨μ„ μž‘μ„±ν•˜μ‹œμ˜€.

#include <iostream>
#include <string>
using namespace std;
int main() {
    string s;
    cin >> s;
    int n = s.size();
    if (n%3 == 1) {
        cout << s[0];
    } else if (n%3 == 2) {
        cout << (s[0]-'0')*2 + (s[1]-'0');
    }
    for (int i=n%3; i<n; i+=3) {
        cout << (s[i]-'0')*4 + (s[i+1]-'0')*2 + (s[i+2]-'0');
    }
    cout << '\n';
    return 0;
}

8 to 2

  • 8μ§„μˆ˜κ°€ μ£Όμ–΄μ‘Œμ„ λ•Œ, 2μ§„μˆ˜λ‘œ λ³€ν™˜ν•˜λŠ” ν”„λ‘œκ·Έλž¨μ„ μž‘μ„±ν•˜μ‹œμ˜€.

#include <cstdio>
#include <string>
#include <iostream>
using namespace std;
string eight[8] = {"000","001","010","011","100","101","110","111"};
int main(){
    string s;
    cin >> s;
    bool st = false;
    if(s.length() == 1 && s[0]-'0' == 0)cout << "0";
    for(int i = 0;i < s.length();i ++){
        int n = s[i]-'0';
        if(!st && n < 4){
            if(n == 0)    continue;
            else if(n == 1)  cout << "1";
            else if(n == 2)  cout << "10";
            else if(n == 3)  cout << "11";
            st = true;
        }
        else{
            cout << eight[n];
            st = true;
        }
    }
    return 0;
}

8 to -2

  • -2진법은 λΆ€ν˜Έ μ—†λŠ” 2μ§„μˆ˜λ‘œ ν‘œν˜„μ΄ λœλ‹€. 2μ§„λ²•μ—μ„œλŠ” 20, 21, 22, 23이 ν‘œν˜„ λ˜μ§€λ§Œ -2μ§„λ²•μ—μ„œλŠ” (-2)0 = 1, (-2)1 = -2, (-2)2 = 4, (-2)3 = -8을 ν‘œν˜„ν•œλ‹€. 10μ§„μˆ˜λ‘œ 1λΆ€ν„° ν‘œν˜„ν•˜μžλ©΄ 1, 110, 111, 100, 101, 11010, 11011, 11000, 11001 등이닀.

  • λ‚˜λ¨Έμ§€κ°€ μŒμˆ˜κ°€ λ‚˜μ˜€λ©΄ μ•ˆλœλ‹€.

  • μ–‘μˆ˜/-2

    • 2둜 λ‚˜λˆ„μ–΄ λ–¨μ–΄μ§€λŠ” 경우

  • 음수/-2

    • 2둜 λ‚˜λˆ„μ–΄ λ–¨μ–΄μ§€λŠ” 경우

/*
 8μ§„μˆ˜κ°€ μ£Όμ–΄μ‘Œμ„ λ•Œ, 2μ§„μˆ˜λ‘œ λ³€ν™˜ν•˜λŠ” ν”„λ‘œκ·Έλž¨μ„ μž‘μ„±ν•˜μ‹œμ˜€.
 첫째 쀄에 8μ§„μˆ˜κ°€ μ£Όμ–΄μ§„λ‹€. μ£Όμ–΄μ§€λŠ” 수의 κΈΈμ΄λŠ” 333,334을 λ„˜μ§€ μ•ŠλŠ”λ‹€.
 첫째 쀄에 μ£Όμ–΄μ§„ 수λ₯Ό 2μ§„μˆ˜λ‘œ λ³€ν™˜ν•˜μ—¬ 좜λ ₯ν•œλ‹€. μˆ˜κ°€ 0인 경우λ₯Ό μ œμ™Έν•˜κ³ λŠ” λ°˜λ“œμ‹œ 1둜 μ‹œμž‘ν•΄μ•Ό ν•œλ‹€.
*/
#include <algorithm>
#include <string>
#include <iostream>
using namespace std;

int main(){
    int n;
    scanf("%d",&n);
    string ans="";
    if(n==0)printf("%d",n);
    while(n!=1){
        if(n>0){
            if(n%(-2)==0){
                ans+='0';
            }else{
                ans+='1';
            }
        }else{
            if(n%(-2)==0){
                ans+='0';
            }else{
                ans+='1';
                n-=1;
            }
        }
        n/=-2;
    }
    ans+='1';
    reverse(ans.begin(), ans.end());
    cout << ans;
}

A to B

  • A진법을 Bμ§„λ²•μœΌλ‘œ λ°”κΎΈκΈ°

  • A진법 -> 10진법 -> B진법

#include <iostream>
using namespace std;
void convert(int num, int base) {
    if (num == 0) return;
    convert(num/base, base);
    printf("%d ",num%base);
}
int main() {
    int a,b;
    cin >> a >> b;
    int n;
    cin >> n;
    int ans = 0;
    for (int i=0; i<n; i++) {
        int x;
        cin >> x;
        ans = ans * a + x;
    }
    convert(ans,b);
    return 0;
}

μ†Œμˆ˜

μ•½μˆ˜κ°€ 1κ³Ό 자기 μžμ‹  밖에 μ—†λŠ” μˆ˜μ΄λ‹€.

N이 μ†Œμˆ˜κ°€ 되렀면, 2이상 N-1μ΄ν•˜μ˜ μžμ—°μˆ˜λ‘œ λ‚˜λˆ„μ–΄ λ–¨μ–΄μ§€λ©΄ μ•ˆλœλ‹€.

κ΅¬ν˜„ 방법

방법1

bool prime(int n){
    if(n<2)return false;
    for(int i=2;i<n;i++){
        if(n%i==0)return false;
    }
    return true;
}
  • μ‹œκ°„λ³΅μž‘λ„ : O(n)

방법2

N의 μ•½μˆ˜ μ€‘μ—μ„œ κ°€μž₯ 큰 것은 N/2보닀 μž‘κ±°λ‚˜ κ°™κΈ° λ•Œλ¬Έμ— 2이상 N/2μ΄ν•˜μ˜ μžμ—°μˆ˜λ‘œ λ‚˜λˆ„μ–΄ λ–¨μ–΄μ§€λ©΄λœλ‹€.

bool prime(int n){
    if(n<2)return false;
    for(int i=2;i<=n/2;i++){
        if(n%i==0)return false;
    }
    return true;
}
  • μ‹œκ°„λ³΅μž‘λ„ : O(n)

방법3

N이 μ†Œμˆ˜κ°€ μ•„λ‹ˆλΌλ©΄, N=a*b 둜 λ‚˜νƒ€λ‚Ό 수 μžˆλ‹€.(a<=b)

두 수 a와 b의 차이가 κ°€μž₯ μž‘μ€ κ²½μš°λŠ” 루트(n) 이닀. κ·ΈλŸ¬λ―€λ‘œ 2이상 루트(n)μ΄ν•˜ 의 μžμ—°μˆ˜λ‘œ λ‚˜λˆ„μ–΄ λ–¨μ–΄μ§€μ§€ μ•ŠλŠ” 수λ₯Ό λΉ„κ΅ν•΄λ³΄λ©΄λœλ‹€.

예λ₯Ό λ“€μ–΄, N=24이닀.

  • N=24의 μ•½μˆ˜ : 1 2 3 4 6 8 12 24

  • 1κ³Ό μžκΈ°μžμ‹ (24)μ œμ™Έν•œ μ•½μˆ˜ : 2 3 4 6 8 12

  • 루트(24) λŠ” μ•½ 4.xxxx이닀. 루트(24)λ₯Ό κΈ°μ€€μœΌλ‘œ 반으둜 λ‚˜λˆŒ 수 μžˆλ‹€.

  • 2 3 4 | 6 8 12

  • 루트(24)λ₯Ό κΈ°μ€€μœΌλ‘œ μž‘μ€μˆ˜μ—μ„œ λ‚˜λˆ„μ–΄ λ–¨μ–΄μ§€λŠ” μˆ˜κ°€ μžˆλ‹€λ©΄ 큰 μͺ½μ—μ„œλ„ λ‚˜λˆ„μ–΄ λ–¨μ–΄μ§€λŠ” μˆ˜κ°€ μžˆλŠ” 것이닀. κ·ΈλŸ¬λ―€λ‘œ κΈ°μ€€μ—μ„œ μž‘μ€μˆ˜λ₯Ό 비ꡐ해 λ‚˜λˆ„μ–΄ λ–¨μ–΄μ§€μ§€ μ•ŠλŠ” 수λ₯Ό 찾으면 λœλ‹€.

bool prime(int n){
    if(n<2)return false;
    for(int i=2;i*i<=n/2;i++){
        if(n%i==0)return false;
    }
    return true;
}
  • μ‹œκ°„λ³΅μž‘λ„ : O(root(n))

μ£Όμ–΄μ§„ 수 N개 μ€‘μ—μ„œ μ†Œμˆ˜κ°€ λͺ‡ κ°œμΈμ§€ μ°Ύμ•„μ„œ 좜λ ₯ν•˜λŠ” ν”„λ‘œκ·Έλž¨μ„ μž‘μ„±ν•˜μ‹œμ˜€.

bool prime(int n){
    if(n<2)return false;
    for(int i=2;i*i<=n;i++){
        if(n%i==0)return false;
    }
    return true;
}

int main(int argc, const char * argv[]) {
    int n;
    int num,count = 0;
    scanf("%d",&n);

    while(n--){
        scanf("%d",&i);
        if(prime(num))count++;
    }
    printf("%d",count);
}

μ—λΌν† μŠ€ν…Œλ„€μŠ€μ˜ 체

1λΆ€ν„° NκΉŒμ§€ λ²”μœ„ μ•ˆμ— λ“€μ–΄κ°€λŠ” λͺ¨λ“  μ†Œμˆ˜λ₯Ό κ΅¬ν•˜λ €λ©΄ μ—λΌν† μŠ€ν…Œλ„€μŠ€μ˜ 체λ₯Ό μ‚¬μš©ν•œλ‹€. μ™œλƒν•˜λ©΄ 각각의 μˆ˜μ— λŒ€ν•΄μ„œ μ†Œμˆ˜μΈμ§€ μ•„λ‹Œμ§€ κ²€μ‚¬ν•˜λŠ”λ° O(root(N))μ‹œκ°„μ΄ κ±Έλ¦¬λŠ”λ°, N개λ₯Ό κ²€μ‚¬ν•΄μ•Όν•˜λ―€λ‘œ O(Nroot(N))의 μ‹œκ°„μ΄ κ±Έλ¦¬λ―€λ‘œ λ„ˆλ¬΄ κΈ΄ μ‹œκ°„μ΄ κ±Έλ¦°λ‹€.

μ—λΌν† μŠ€ν…Œλ„€μŠ€μ˜ μ²΄λŠ” λ‹€μŒκ³Ό 같은 κ·œμΉ™μœΌλ‘œ κ΅¬ν•œλ‹€.

  1. 2λΆ€ν„° NκΉŒμ§€ λͺ¨λ“  수λ₯Ό μ¨λ†“λŠ”λ‹€.

  2. 아직 μ§€μ›Œμ§€μ§€ μ•Šμ€ 수 μ€‘μ—μ„œ κ°€μž₯ μž‘μ€ 수λ₯Ό μ°ΎλŠ”λ‹€.

  3. κ·Έ μˆ˜λŠ” μ†Œμˆ˜μ΄λ‹€.

  4. 이제 κ·Έ 수의 배수λ₯Ό λͺ¨λ‘ μ§€μš΄λ‹€.

μ΄λ ‡κ²Œ μ§€μš°κ³  남아 μžˆλŠ” μˆ˜κ°€ λͺ¨λ‘ μ†Œμˆ˜μ΄λ‹€.

κ΅¬ν˜„

int p[100];        //μ†Œμˆ˜ μ €μž₯ν•  λ°°μ—΄
int total_prime = 0; //μ†Œμˆ˜μ˜ 개수
bool c[101];    //μ§€μ›Œμ§€λ©΄ true, μ•„λ‹ˆλ©΄ false
int n = 100;    //NκΉŒμ§€μ˜ 수
for(int i=2;i<=n;i++){
    if(c[i]==false){
        p[total_prime++]=i;
        for(int j=i*i;j<=n;j+=i)c[j]=true;
    }
}
  • μ‹œκ°„λ³΅μž‘λ„ : O(Nloglog(N))

    • n/2 + n/3 + n/4 + …. = loglog(N)

  • μ£Όμ˜ν•  점 i*iλŠ” N의 λ²”μœ„μ— λ”°λΌμ„œ i+i둜 λ³€κ²½ν•΄μ€€λ‹€.(λ°±λ§Œμ΄μƒμΌ 경우 λ²”μœ„ 초과)

M이상 Nμ΄ν•˜μ˜ μ†Œμˆ˜λ₯Ό λͺ¨λ‘ 좜λ ₯ν•˜λŠ” ν”„λ‘œκ·Έλž¨μ„ μž‘μ„±ν•˜μ‹œμ˜€.

#include <iostream>
using namespace std;
#define MAX 1000000
int p[MAX];
int total_prime=0;
bool check_prime[MAX+1];

int main(int argc, const char * argv[]) {

    int n,m;
    scanf("%d %d",&m, &n);

    for(int i=2;i<=n;i++){
        if(check_prime[i]==false){
            if(i>=m){
                p[total_prime++]=i;
                printf("%d\n",i);
            }
            for(int j=i+i;j<=n;j+=i){
                check_prime[j]=true;
            }
        }
    }
}

증λͺ…이 λ˜μ§€ μ•Šμ€ λ¬Έμ œμ—¬μ„œ 좔츑이라고 ν•œλ‹€.

  • 2보닀 큰 λͺ¨λ“  μ§μˆ˜λŠ” 두 μ†Œμˆ˜μ˜ ν•©μœΌλ‘œ ν‘œν˜„μ΄ κ°€λŠ₯ν•˜λ‹€.

  • 5보닀 큰 λͺ¨λ“  ν™€μˆ˜λŠ” μ„Έ μ†Œμˆ˜μ˜ ν•©μœΌλ‘œ ν‘œν˜„μ΄ κ°€λŠ₯ν•˜λ‹€.

  • 10^18μ΄ν•˜μ—μ„œλŠ” 참인 것이 증λͺ…λ˜μ–΄ μžˆλ‹€.

#include <iostream>
using namespace std;
#define MAX 1000000
int p[MAX];
int total_prime=0;
bool check_prime[MAX+1];

int main(int argc, const char * argv[]) {

    int t;    
    for(int i=2;i<=MAX;i++){
        if(check_prime[i]==false){
            p[total_prime++]=i;
            for(int j=i+i;j<=MAX;j+=i){
                check_prime[j]=true;
        }
    }
    while(1){
        scanf("%d",&t);
        if(t==0)break;
        for(int i=1;i<total_prime;i++){
            if(check_prime[t-p[i]]==false){
                printf("%d = %d + %d\n", t, p[i],t-p[i]);
                break;
            }
        }        
    }
}

μ†ŒμΈμˆ˜λΆ„ν•΄

μ •μˆ˜ N을 μ†Œμˆ˜μ˜ 곱으둜 λΆ„ν•΄ν•œ 것이닀.

  • μ†Œμˆ˜λ₯Ό κ΅¬ν•˜μ§€ μ•Šκ³ λ„ ν•΄κ²°ν•  수 μžˆλ‹€.

  • N을 μ†ŒμΈμˆ˜λΆ„ν•΄ ν–ˆμ„ λ•Œ, λ‚˜νƒ€λ‚  수 μžˆλŠ” 인수 μ€‘μ—μ„œ κ°€μž₯ 큰 값은 루트(N)이닀.

for(int i=2;i*i<=n;i++){
    while(n%i==0){
        printf("%d\n",i);
        n/=i;
    }
}
if(n>1){
    printf("%d\n",n);
}

νŒ©ν† λ¦¬μ–Ό

N! = 1* 2 * ... * N

νŒ©ν† λ¦¬μ–Όμ€ 맀우 큰 값이닀.

μš°λ¦¬κ°€ νŒ©ν† λ¦¬μ–Όμ„ ν’€ 수 μžˆλŠ” 규λͺ¨λŠ” 10! = 3628800 κΉŒμ§€μ΄λ‹€.

N!μ—μ„œ 0이 λͺ‡κ°œμΈμ§€ μ•Œμ•„λ‚΄λŠ” λ¬Έμ œμ΄λ‹€.

  • ex) 10! = 3628800

0이 λͺ‡κ°œμΈμ§€λŠ” N!λ₯Ό μ†ŒμΈμˆ˜λΆ„ν•΄ 해보면 μ•Œ 수 μžˆλ‹€.

  • 10! = 2^6 * 3^4 * 7 * (2^2 * 5^2)

ν•˜μ§€λ§Œ μ‹€μ œλ‘œ ꡬ할 λ•Œ μ†ŒμΈμˆ˜λΆ„ν•΄λ₯Ό λ‹€ ν•  ν•„μš”λŠ” μ—†λ‹€. 5의 κ°œμˆ˜κ°€ 항상 2의 κ°œμˆ˜λ³΄λ‹€ 적기 λ•Œλ¬Έμ— 5의 개수만 μ„Έμ–΄μ£Όλ©΄λœλ‹€.

N!의 0의 개수 = [N/5]+[N/5^2]+[N/5^3]+…

예λ₯Ό λ“€μ–΄ 100!이면 (100/5 = 20) + (100/25) = 24κ°œμ΄λ‹€.

#include <iostream>
using namespace std;

int main(int argc, const char * argv[]) {
    int n;
    scanf("%d",&n);
    int res = 0;
    for (int i=5; i<=n; i*=5) {
        res += n/i;
    }

    printf("%d",res);
}

nCm의 끝자리 0의 개수λ₯Ό κ΅¬ν•˜λŠ” λ¬Έμ œμ΄λ‹€. νŒ©ν† λ¦¬μ–Όμ—μ„œλŠ” 2의 κ°œμˆ˜κ°€ 5의 κ°œμˆ˜λ³΄λ‹€ 항상 많기 λ•Œλ¬Έμ— 5만 μ„Έμ–΄μ€¬μ§€λ§Œ, 쑰합은 μ–΄λ–»κ²Œ 될지 λͺ¨λ₯΄κΈ° λ•Œλ¬Έμ— 2와 5의 개수λ₯Ό λͺ¨λ‘ μ„Έμ–΄μ€˜μ•Όν•œλ‹€.

#include <iostream>
using namespace std;

int main(int argc, const char * argv[]) {
    long long  n,m;
    scanf("%lld %lld",&n,&m);
    long long  two=0, fiv=0;
    long long i;
    for (i=2; i<=n; i*=2) {
        two += n/i;
    }
    for (i=2; i<=n-m; i*=2) {
        two -= (n-m)/i;
    }
    for (i=2; i<=m; i*=2) {
        two -= m/i;
    }
    for (i=5; i<=n; i*=5) {
        fiv += n/i;
    }
    for (i=5; i<=n-m; i*=5) {
        fiv -= (n-m)/i;
    }
    for (i=5; i<=m; i*=5) {
        fiv -= m/i;
    }
    if(fiv>two)printf("%lld",two);
    else printf("%d",fiv);
}
PreviousArray, Struct, PointerNextSort

Last updated 4 years ago

Was this helpful?

μ—μ„œ νŒ©ν† λ¦¬μ–Όμ„ μˆœν™˜κ³Ό 반볡으둜 ν’€μ–΄λ³Έ λ¬Έμ œκ°€ μžˆλ‹€.

μ†Œμˆ˜ μ°ΎκΈ°
μ†Œμˆ˜ κ΅¬ν•˜κΈ°
κ³¨λ“œλ°”νμ˜ μΆ”μΈ‘
μ†ŒμΈμˆ˜λΆ„ν•΄ κ΅¬ν•˜κΈ°
03.Recursive
νŒ©ν† λ¦¬μ–Ό 0의 개수
μ‘°ν•© 0의 개수