250x250
Rainbow๐ŸŒˆCoder
My dev Note๐Ÿ“’
Rainbow๐ŸŒˆCoder
์ „์ฒด ๋ฐฉ๋ฌธ์ž
์˜ค๋Š˜
์–ด์ œ
  • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (411)
    • ๊ณต์ง€์‚ฌํ•ญ (0)
    • Debugger (10)
      • Visual Studio Debugger (1)
      • Chrome DevTools (3)
      • Visual Studio Code Debugger (4)
      • eclipse (1)
      • intelliJ (1)
    • OOP (2)
      • OOP (2)
    • TypeScript (54)
      • ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript (54)
    • Javascript (87)
      • Javascript (45)
      • Node.js (19)
      • React (5)
      • FE ๊ฐœ๋ฐœํ™˜๊ฒฝ์„ค์ • (3)
      • React์™€ Node ๊ฐ™์ด ๋•Œ๋ ค์žก๊ธฐ (6)
      • next.js (2)
      • pixi.js (7)
    • ๋งˆํฌ์—… (23)
      • Html & Css (23)
    • C# (80)
      • C# (12)
      • ์ด๊ฒƒ์ด C#์ด๋‹ค (68)
    • C++ (30)
      • c++ (27)
      • win api (3)
    • Unity (18)
      • Unity(๊ธฐ์ดˆ) (8)
      • Unity(C#์ค‘๊ธ‰) (5)
      • ์œ ๋‹ˆํ‹ฐ ํฌํ†ค(๋„คํŠธ์›Œํฌ) (4)
      • unity c# MyCode (1)
    • Java & Spring (29)
      • Java (11)
      • ์Šคํ”„๋ง (8)
      • Java Algorithm (9)
      • Javs Data Structures (1)
    • ์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜ (15)
      • ์ž๋ฃŒ๊ตฌ์กฐ (5)
      • ์•Œ๊ณ ๋ฆฌ์ฆ˜ (10)
    • ํ˜•์ƒ๊ด€๋ฆฌ (15)
      • Git (11)
      • ์†Œ์ŠคํŠธ๋ฆฌ (3)
    • ๊ทธ๋ž˜ํ”ฝ์Šค (7)
      • WebGl (7)
    • AWS (3)
      • aws (3)
    • ๋ฆฌ๋ˆ…์Šค (5)
      • ๋ฆฌ๋ˆ…์Šค (5)
    • ์ฑ… ๋ฆฌ๋ทฐ (13)
      • ํด๋ฆฐ์ฝ”๋“œ(์ฑ…๋ฆฌ๋ทฐ) (3)
      • ์œ ์ง€๋ณด์ˆ˜๊ฐ€๋Šฅํ•œ์ฝ”๋”ฉ์˜๊ธฐ์ˆ C#ํŽธ(์ฑ…๋ฆฌ๋ทฐ) (1)
      • ๋ฆฌํŒฉํ† ๋ง(์ž๋ฐ”์Šคํฌ๋ฆฝํŠธํŒ) (9)
    • Server (2)
      • ๊ฒŒ์ž„ ์„œ๋ฒ„(๋„คํŠธ์›Œํฌ, ๋ฉ€ํ‹ฐ์“ฐ๋ ˆ๋“œ,OS) (2)
    • ์„ค๊ณ„, ์•„ํ‚คํ…์ณ (4)
    • ํŒŒ์ด์ฌ (5)
    • ๋””์ž์ธํŒจํ„ด (2)
    • mocha (2)
    • Jest (1)
    • Spine (1)
    • ์ธ๊ณต์ง€๋Šฅ (1)
      • ํ˜ผ์ž๊ณต๋ถ€ํ•˜๋Š”๋จธ์‹ ๋Ÿฌ๋‹+๋”ฅ๋Ÿฌ๋‹ (1)

๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

  • ํ™ˆ
  • ํƒœ๊ทธ
  • ๋ฐฉ๋ช…๋ก

๊ณต์ง€์‚ฌํ•ญ

์ธ๊ธฐ ๊ธ€

ํƒœ๊ทธ

  • ใ…ฃใ„ท
  • MySQL
  • ์ปดํฌ์ง€์…˜
  • ์œ„์ž„

์ตœ๊ทผ ๋Œ“๊ธ€

์ตœ๊ทผ ๊ธ€

ํ‹ฐ์Šคํ† ๋ฆฌ

hELLO ยท Designed By ์ •์ƒ์šฐ.
Rainbow๐ŸŒˆCoder

My dev Note๐Ÿ“’

์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜/์ž๋ฃŒ๊ตฌ์กฐ

[์ˆœํ™˜๊ณผ ๋ฐ˜๋ณต] ํŒฉํ† ๋ฆฌ์–ผ ๊ณ„์‚ฐ ํ”„๋กœ๊ทธ๋žจ

2022. 1. 31. 15:20
728x90

ํŒฉํ† ๋ฆฌ์–ผ์„ ์ˆœํ™˜, ๋ฐ˜๋ณต ๊ฐœ๋…์— ๋งž์ถ”์–ด์„œ ํ”„๋กœ๊ทธ๋žจ์„ ์งœ๋ฉด ๋‹ค์Œ๊ณผ ๊ฐ™๋‹ค.

 

1. ์ˆœํ™˜

 

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

int factorial(int n)
{
    cout << n << "\n";
    if (n <= 1)
    {
        return n;
    }
    else
    {
        return (n * factorial(n - 1));
    }
}

int main() 
{
    int k = factorial(8);
    cout << k;
    return 0;
}

์ถœ๋ ฅ

8
7
6
5
4
3
2
1
40320

์Šคํƒ ํ˜ธ์ถœ์— ๋”ฐ๋ผ(๋’ค์— ํ˜ธ์ถœ๋œ ํ•จ์ˆ˜๋ถ€ํ„ฐ ๋ฆฌํ„ด)

        return (n * factorial(n - 1)); ์ˆœ์„œ๋Œ€๋กœ

return (1 * 1);

return (2 * 1);

return (3 * 2);

return (4 * 6);

return (5 * 24);

return (6 * 120);

return (7 * 720);

return (8 * 5040) = 40320 ์ด ๋œ๋‹ค. 

 

์œ„์™€ ๊ฐ™์ด ํ”„๋กœ๊ทธ๋žจ์„ ์ž‘์„ฑํ•˜๋ฉด,(ํ”„๋กœ๊ทธ๋ž˜๋ฐ ์–ธ์–ด์—์„œ ํ•˜๋‚˜์˜ ํ•จ์ˆ˜๊ฐ€ ์ž๊ธฐ ์ž์‹ ์„ ๋‹ค์‹œ ํ˜ธ์ถœ)

์‚ฌ์‹ค์ƒ ๋‹ค๋ฅธ ํ•จ์ˆ˜๋ฅผ ํ˜ธ์ถœํ•˜๋Š” ๊ฒƒ๊ณผ ๋™์ผํ•˜๋‹ค.

๋ณต๊ท€ ์ฃผ์†Œ๊ฐ€ ์‹œ์Šคํ…œ ์Šคํƒ์— ์ €์žฅ๋˜๊ณ 

ํ˜ธ์ถœ๋˜๋Š” ํ•จ์ˆ˜๋ฅผ ์œ„ํ•œ ๋งค๊ฐœ๋ณ€์ˆ˜์™€ ์ง€์—ญ ๋ณ€์ˆ˜๋ฅผ ์Šคํƒ์œผ๋กœ๋ถ€ํ„ฐ ํ• ๋‹น๋ฐ›๋Š”๋‹ค.

์ด๋Ÿฌํ•œ ํ•จ์ˆ˜๋ฅผ ์œ„ํ•œ ์‹œ์Šคํ…œ ์Šคํƒ์—์„œ์˜ ๊ณต๊ฐ„์„ ํ™œ์„ฑ ๋ ˆ์ฝ”๋“œ๋ผ๊ณ  ํ•œ๋‹ค.

 

ํ˜ธ์ถœ๋œ ํ•จ์ˆ˜๊ฐ€ ์ž๊ธฐ ์ž์‹ ์ด๋ฏ€๋กœ ์ž๊ธฐ ์ž์‹ ์˜ ์‹œ์ž‘ ์œ„์น˜๋กœ ์ ํ”„ํ•˜์—ฌ ์ˆ˜ํ–‰์„ ์‹œ์ž‘ํ•œ๋‹ค.

ํ˜ธ์ถœ๋œ ํ•จ์ˆ˜๊ฐ€ ๋๋‚˜๊ฒŒ ๋˜๋ฉด ์‹œ์Šคํ…œ ์Šคํƒ์—์„œ ๋ณต๊ท€ ์ฃผ์†Œ๋ฅผ ์ถ”์ถœํ•˜์—ฌ ํ˜ธ์ถœํ•œ ํ•จ์ˆ˜๋กœ ๋˜๋Œ์•„๊ฐ€๊ฒŒ ๋œ๋‹ค.

์ˆœํ™˜ํ˜ธ์ถœ์ด ๊ณ„์† ์ค‘์ฒฉ๋ ์ˆ˜๋ก ์‹œ์Šคํ…œ ์Šคํƒ์—๋Š” ํ™œ์„ฑ๋ ˆ์ฝ”๋“œ๋“ค์ด ์Œ“์ด๊ฒŒ ๋œ๋‹ค.

 

ํ•จ์ˆ˜ํ˜ธ์ถœ๋งˆ๋‹ค ์ƒˆ๋กœ์šด ์ง€์—ญ๋ณ€์ˆ˜๋ฅผ ๋งŒ๋“ค ์ˆ˜ ์žˆ๊ธฐ์— ์ˆœํ™˜ํ˜ธ์ถœ์ด ๊ฐ€๋Šฅํ•˜๋‹ค.

 

์ด์™€ ๊ฐ™์€ ์ˆœํ™˜ ์•Œ๊ณ ๋ฆฌ์ฆ˜์€ 

์ž๊ธฐ ์ž์‹ ์„ ์ˆœํ™˜์ ์œผ๋กœ ํ˜ธ์ถœํ•˜๋Š” ๋ถ€๋ถ„๊ณผ ์ˆœํ™˜ํ˜ธ์ถœ์„ ๋ฉˆ์ถ”๋Š” ๋ถ€๋ถ„์œผ๋กœ ๊ตฌ์„ฑ๋˜์–ด ์žˆ๋‹ค.

๋งŒ์•ฝ ์ˆœํ™˜ ํ˜ธ์ถœ์„ ๋ฉˆ์ถ”๋Š” ๋ถ€๋ถ„์ด ์—†๋‹ค๋ฉด ์‹œ์Šคํ…œ ์Šคํƒ์„ ๋‹ค ์‚ฌ์šฉํ•  ๋•Œ๊นŒ์ง€ ์ˆœํ™˜์ ์œผ๋กœ ํ˜ธ์ถœ๋˜๋‹ค๊ฐ€ ๊ฒฐ๊ตญ ์˜ค๋ฅ˜๋ฅผ ๋‚ด๋ฉด์„œ ๋ฉˆ์ถœ ๊ฒƒ์ด๋‹ค. ๋”ฐ๋ผ์„œ ๋ฐ˜๋“œ์‹œ ์ˆœํ™˜ ํ˜ธ์ถœ์—๋Š” ์ˆœํ™˜ ํ˜ธ์ถœ์„ ๋ฉˆ์ถ”๋Š” ๋ฌธ์žฅ์ด ํฌํ•จ๋˜์–ด์•ผ ํ•œ๋‹ค.

 

2. ๋ฐ˜๋ณต

์ผ๋ฐ˜์ ์œผ๋กœ ์ˆœํ™˜์€ ํ•จ์ˆ˜ ํ˜ธ์ถœ์„ ํ•˜๊ฒŒ ๋˜๋ฏ€๋กœ ๋ฐ˜๋ณต์— ๋น„ํ•ด ์ˆ˜ํ–‰์†๋„ ๋ฉด์—์„œ ๋–จ์–ด์ง„๋‹ค.

์•„๋ž˜์™€ ๊ฐ™์ด ๋ฐ˜๋ณต ํ”„๋กœ๊ทธ๋žจ์œผ๋กœ ๋ณ€๊ฒฝํ•  ์ˆ˜ ์žˆ๋‹ค. 

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

int factorial(int n)
{
    int i, result = 1;
    for (i = 1; i <= n; i++)
    {
        cout << i << "\n";
        result = result * i;
    }
    return result;
}

int main() 
{
    int k = factorial(8);
    cout << k;
    return 0;
}
1
2
3
4
5
6
7
8
40320

 

 

<์ •๋ฆฌ>

์ˆœํ™˜์€ ์•Œ๊ณ ๋ฆฌ์ฆ˜์˜ ์ •์˜๊ฐ€ ์ˆœํ™˜์ ์œผ๋กœ ๋˜์–ด ์žˆ๋Š” ๊ฒฝ์šฐ์— ์œ ๋ฆฌํ•˜๋‹ค.

ํŒฉํ† ๋ฆฌ์–ผ ํ•จ์ˆ˜, ํ”ผ๋ณด๋‚˜์น˜ ์ˆ˜์—ด, ์ดํ•ญ๊ณ„์ˆ˜ ๊ณ„์‚ฐ, ์ด์ง„ ํŠธ๋ฆฌ ์•Œ๊ณ ๋ฆฌ์ฆ˜, ์ด์ง„ ํƒ์ƒ‰, ํ•˜๋…ธ์ด ํƒ‘ ๋ฌธ์ œ๋“ค์€ ์ˆœํ™˜ ์•Œ๊ณ ๋ฆฌ์ฆ˜์„ ์“ฐ๋Š” ๊ฒƒ์ด ์ž์—ฐ์Šค๋Ÿฌ์šด ์•Œ๊ณ ๋ฆฌ์ฆ˜๋“ค์ด๋‹ค.

728x90

'์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜ > ์ž๋ฃŒ๊ตฌ์กฐ' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[C# ์ž๋ฃŒ๊ตฌ์กฐ] ๋™์  ๋ฐฐ์—ด(List: C++vector์™€ ์œ ์‚ฌํ•จ) ๊ตฌํ˜„  (0) 2022.02.04
[C# ์ž๋ฃŒ๊ตฌ์กฐ] ์„ ํ˜• ์ž๋ฃŒ ๊ตฌ์กฐ ( ๋ฐฐ์—ด vs ๋™์  ๋ฐฐ์—ด vs ์—ฐ๊ฒฐ ๋ฆฌ์ŠคํŠธ)  (0) 2022.02.03
C# Queue์™€ Stack ํŠน์„ฑ์„ LinkedList๋กœ ๊ทธ๋Œ€๋กœ ๊ตฌํ˜„  (0) 2022.01.25
[C++]์›ํ˜•ํ ๊ตฌํ˜„, ์ค„์„œ๊ธฐ ์˜ˆ์‹œ  (0) 2021.12.15
    '์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜/์ž๋ฃŒ๊ตฌ์กฐ' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • [C# ์ž๋ฃŒ๊ตฌ์กฐ] ๋™์  ๋ฐฐ์—ด(List: C++vector์™€ ์œ ์‚ฌํ•จ) ๊ตฌํ˜„
    • [C# ์ž๋ฃŒ๊ตฌ์กฐ] ์„ ํ˜• ์ž๋ฃŒ ๊ตฌ์กฐ ( ๋ฐฐ์—ด vs ๋™์  ๋ฐฐ์—ด vs ์—ฐ๊ฒฐ ๋ฆฌ์ŠคํŠธ)
    • C# Queue์™€ Stack ํŠน์„ฑ์„ LinkedList๋กœ ๊ทธ๋Œ€๋กœ ๊ตฌํ˜„
    • [C++]์›ํ˜•ํ ๊ตฌํ˜„, ์ค„์„œ๊ธฐ ์˜ˆ์‹œ
    Rainbow๐ŸŒˆCoder
    Rainbow๐ŸŒˆCoder
    ๋ชฐ๋ผ๋„ ๊ฒฐ๊ตญ์€ ์•„๋Š” ๊ฐœ๋ฐœ์ž, ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ๋˜๊ธฐ ์œ„ํ•œ ๋งค์ผ์˜ ํ•œ๊ฑธ์Œ

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”