Conditions et Boucles
Instructions Conditionnelles (instructions if)
Instruction if de base
age = 20
if age >= 18:
print("성인입니다")
# 출력: 성인입니다
Instruction if-else
age = 15
if age >= 18:
print("성인입니다")
else:
print("미성년자입니다")
# 출력: 미성년자입니다
Instruction if-elif-else
score = 85
if score >= 90:
grade = "A"
elif score >= 80:
grade = "B"
elif score >= 70:
grade = "C"
elif score >= 60:
grade = "D"
else:
grade = "F"
print(f"학점: {grade}") # 학점: B
Instruction if imbriquée
age = 20
has_license = True
if age >= 18:
if has_license:
print("운전 가능합니다")
else:
print("면허를 취득하세요")
else:
print("성인이 되어야 합니다")
Expression Conditionnelle (Opérateur Ternaire)
# if-else sur une ligne
age = 20
status = "성인" if age >= 18 else "미성년자"
print(status) # 성인
# Expressions conditionnelles imbriquées
score = 85
grade = "A" if score >= 90 else "B" if score >= 80 else "C"
print(grade) # B
# Exemple pratique
numbers = [1, -2, 3, -4, 5]
positive = [n if n > 0 else 0 for n in numbers]
print(positive) # [1, 0, 3, 0, 5]
Combiner plusieurs conditions
age = 25
income = 3000
# Opérateur and
if age >= 18 and income >= 2000:
print("대출 가능")
# Opérateur or
if age < 18 or age >= 65:
print("할인 대상")
# Opérateur not
is_weekend = False
if not is_weekend:
print("평일입니다")
# Conditions complexes
score = 85
attendance = 0.9
if (score >= 80 and attendance >= 0.8) or score >= 95:
print("합격")
Boucles (boucle for)
Boucle for de base
# Itérer sur une liste
fruits = ["사과", "바나나", "체리"]
for fruit in fruits:
print(fruit)
# Itérer sur une chaîne
for char in "Python":
print(char)
# Utilisation de range
for i in range(5):
print(i) # 0, 1, 2, 3, 4
for i in range(1, 6):
print(i) # 1, 2, 3, 4, 5
for i in range(0, 10, 2):
print(i) # 0, 2, 4, 6, 8
Index et valeur avec enumerate
fruits = ["사과", "바나나", "체리"]
for index, fruit in enumerate(fruits):
print(f"{index}: {fruit}")
# 0: 사과
# 1: 바나나
# 2: 체리
# Spécifier l'index de départ
for index, fruit in enumerate(fruits, 1):
print(f"{index}. {fruit}")
# 1. 사과
# 2. 바나나
# 3. 체리
Itérer sur plusieurs séquences simultanément avec zip
names = ["홍길동", "김철수", "이영희"]
scores = [85, 92, 78]
for name, score in zip(names, scores):
print(f"{name}: {score}점")
# 홍길동: 85점
# 김철수: 92점
# 이영희: 78점
# Longueurs différentes (s'arrête à la plus courte)
numbers = [1, 2, 3, 4, 5]
letters = ['a', 'b', 'c']
for num, letter in zip(numbers, letters):
print(num, letter)
# 1 a
# 2 b
# 3 c
Itérer sur un dictionnaire
person = {"name": "홍길동", "age": 25, "city": "서울"}
# Itérer sur les clés
for key in person:
print(key)
# Itérer sur les valeurs
for value in person.values():
print(value)
# Itérer sur les paires clé-valeur
for key, value in person.items():
print(f"{key}: {value}")
Boucles imbriquées
# Table de multiplication
for i in range(2, 10):
for j in range(1, 10):
print(f"{i} x {j} = {i*j}")
print() # 단 사이 빈 줄
# Liste 2D
matrix = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
for row in matrix:
for value in row:
print(value, end=" ")
print() # 줄바꿈
Boucles (boucle while)
Boucle while de base
# Compte à rebours
count = 5
while count > 0:
print(count)
count -= 1
print("발사!")
# Jusqu'à ce que la condition soit remplie
number = 1
while number < 100:
number *= 2
print(number) # 128
Boucle infinie
# Répéter l'entrée utilisateur
while True:
answer = input("계속하시겠습니까? (y/n): ")
if answer.lower() == 'n':
break
print("계속합니다...")
print("종료")
while-else
# else s'exécute lorsque la condition devient False (fin normale)
count = 0
while count < 3:
print(count)
count += 1
else:
print("정상 종료")
# else ne s'exécute pas lorsqu'on termine avec break
count = 0
while count < 10:
if count == 3:
break
count += 1
else:
print("이 부분은 실행 안 됨")
Contrôle des Boucles
break - Sortir de la boucle
# Sortir lorsque la valeur souhaitée est trouvée
numbers = [1, 3, 5, 7, 9, 2, 4, 6]
for num in numbers:
if num % 2 == 0:
print(f"첫 번째 짝수: {num}")
break
# break dans les boucles imbriquées
found = False
for i in range(10):
for j in range(10):
if i * j > 50:
found = True
break
if found:
break
continue - Passer à l'itération suivante
# Imprimer uniquement les nombres impairs
for i in range(1, 11):
if i % 2 == 0:
continue
print(i) # 1, 3, 5, 7, 9
# Ignorer des valeurs spécifiques
words = ["apple", "banana", "", "cherry", ""]
for word in words:
if not word:
continue
print(word.upper())
pass - Ne rien faire
# Code à implémenter plus tard
for i in range(5):
if i == 2:
pass # TODO: 나중에 구현
else:
print(i)
# Classe ou fonction vide
class MyClass:
pass # 일단 뼈대만
def my_function():
pass # 나중에 구현
Exemples Pratiques
Vérifier un nombre premier
def is_prime(n):
"""소수 판별"""
if n < 2:
return False
for i in range(2, int(n ** 0.5) + 1):
if n % i == 0:
return False
return True
# 100 이하 소수 출력
print("100 이하 소수:")
for num in range(2, 101):
if is_prime(num):
print(num, end=" ")
Plus Grand Commun Diviseur (PGCD)
def gcd(a, b):
"""유클리드 호제법"""
while b != 0:
a, b = b, a % b
return a
print(gcd(48, 18)) # 6
print(gcd(100, 75)) # 25
Suite de Fibonacci
def fibonacci(n):
"""n번째 피보나치 수"""
if n <= 1:
return n
a, b = 0, 1
for _ in range(2, n + 1):
a, b = b, a + b
return b
# 처음 10개 출력
print("피보나치 수열:")
for i in range(10):
print(fibonacci(i), end=" ")
Jeu de devinette de nombres
import random
def guessing_game():
"""숫자 맞추기 게임"""
answer = random.randint(1, 100)
attempts = 0
max_attempts = 10
print("1부터 100 사이의 숫자를 맞춰보세요!")
print(f"기회는 {max_attempts}번입니다.")
while attempts < max_attempts:
try:
guess = int(input(f"\n남은 기회 {max_attempts - attempts}번 > "))
attempts += 1
if guess < answer:
print("UP! 더 큰 숫자입니다.")
elif guess > answer:
print("DOWN! 더 작은 숫자입니다.")
else:
print(f"정답! {attempts}번 만에 맞췄습니다!")
return True
except ValueError:
print("숫자를 입력하세요!")
continue
print(f"\n실패! 정답은 {answer}였습니다.")
return False
# 게임 실행
guessing_game()
Imprimer un calendrier
def print_calendar(year, month):
"""간단한 달력 출력"""
import calendar
# 해당 월의 달력
cal = calendar.monthcalendar(year, month)
# 헤더
print(f"\n{'':^20}")
print(f"{year}년 {month}월".center(20))
print(f"{'':^20}")
print("월 화 수 목 금 토 일")
print("-" * 22)
# 날짜 출력
for week in cal:
for day in week:
if day == 0:
print(" ", end=" ")
else:
print(f"{day:2d} ", end=" ")
print()
print_calendar(2024, 12)
Calculatrice simple
def calculator():
"""사칙연산 계산기"""
print("=== 계산기 ===")
print("종료하려면 'q'를 입력하세요")
while True:
# 수식 입력
expression = input("\n수식 입력 (예: 2 + 3): ")
if expression.lower() == 'q':
print("종료합니다")
break
try:
# 수식 파싱
parts = expression.split()
if len(parts) != 3:
print("형식: 숫자 연산자 숫자")
continue
num1 = float(parts[0])
operator = parts[1]
num2 = float(parts[2])
# 계산
if operator == '+':
result = num1 + num2
elif operator == '-':
result = num1 - num2
elif operator == '*':
result = num1 * num2
elif operator == '/':
if num2 == 0:
print("0으로 나눌 수 없습니다")
continue
result = num1 / num2
else:
print("지원하지 않는 연산자입니다")
continue
print(f"결과: {result}")
except ValueError:
print("올바른 숫자를 입력하세요")
except Exception as e:
print(f"오류: {e}")
# calculator() # 주석 해제하여 실행
Motifs d'étoiles
def print_patterns():
"""다양한 별 패턴"""
n = 5
# 패턴 1: 삼각형
print("패턴 1:")
for i in range(1, n + 1):
print("*" * i)
print()
# 패턴 2: 역삼각형
print("패턴 2:")
for i in range(n, 0, -1):
print("*" * i)
print()
# 패턴 3: 피라미드
print("패턴 3:")
for i in range(1, n + 1):
spaces = " " * (n - i)
stars = "*" * (2 * i - 1)
print(spaces + stars)
print()
# 패턴 4: 다이아몬드
print("패턴 4:")
# 상단
for i in range(1, n + 1):
print(" " * (n - i) + "*" * (2 * i - 1))
# 하단
for i in range(n - 1, 0, -1):
print(" " * (n - i) + "*" * (2 * i - 1))
print_patterns()
Traitement des notes
def process_grades():
"""성적 입력 및 통계"""
scores = []
print("=== 성적 입력 ===")
print("종료하려면 -1을 입력하세요")
while True:
try:
score = int(input("점수 입력: "))
if score == -1:
break
if score < 0 or score > 100:
print("0~100 사이의 점수를 입력하세요")
continue
scores.append(score)
except ValueError:
print("숫자를 입력하세요")
if not scores:
print("입력된 점수가 없습니다")
return
# 통계 계산
total = sum(scores)
average = total / len(scores)
highest = max(scores)
lowest = min(scores)
# 학점 분포
grade_count = {"A": 0, "B": 0, "C": 0, "D": 0, "F": 0}
for score in scores:
if score >= 90:
grade_count["A"] += 1
elif score >= 80:
grade_count["B"] += 1
elif score >= 70:
grade_count["C"] += 1
elif score >= 60:
grade_count["D"] += 1
else:
grade_count["F"] += 1
# 결과 출력
print("\n=== 성적 통계 ===")
print(f"인원: {len(scores)}명")
print(f"총점: {total}점")
print(f"평균: {average:.1f}점")
print(f"최고점: {highest}점")
print(f"최저점: {lowest}점")
print("\n=== 학점 분포 ===")
for grade, count in grade_count.items():
if count > 0:
print(f"{grade}: {count}명")
# process_grades() # 주석 해제하여 실행
Questions Fréquentes
Q1. Dois-je utiliser for ou while ?
R : Choisissez selon la situation
# for : Lorsque vous connaissez le nombre d'itérations
for i in range(10):
print(i)
# while : Jusqu'à ce qu'une condition soit remplie
while user_input != "quit":
user_input = input("명령: ")
# Choix pratique
# - Itérer sur des collections : for
# - Itération basée sur des conditions : while
# - Boucle infinie : while True
Q2. range vs enumerate, lequel utiliser ?
R : Utilisez enumerate si vous avez besoin à la fois de l'index et de la valeur
fruits = ["사과", "바나나", "체리"]
# ❌ Non recommandé
for i in range(len(fruits)):
print(f"{i}: {fruits[i]}")
# ✅ Recommandé
for i, fruit in enumerate(fruits):
print(f"{i}: {fruit}")
Q3. Quelle est la différence entre break et return ?
R : break sort uniquement de la boucle, return sort de la fonction
def find_number(numbers, target):
for num in numbers:
if num == target:
return num # 함수 종료
return None
def process_data(data):
for item in data:
if item < 0:
break # 반복문만 종료
print(item)
print("함수는 계속 실행") # 이 부분은 실행됨
Q4. Comment prévenir les boucles infinies ?
R : Clarifiez les conditions et les conditions de sortie
# ❌ Boucle infinie dangereuse
count = 0
while count < 10:
print(count)
# count를 증가시키지 않음!
# ✅ Boucle sûre
count = 0
max_iterations = 1000 # 안전장치
while count < 10 and max_iterations > 0:
print(count)
count += 1
max_iterations -= 1
# ✅ Condition de sortie claire
while True:
user_input = input("입력 (q=종료): ")
if user_input == 'q':
break
process(user_input)
Prochaines Étapes
Vous avez maîtrisé le contrôle du flux du programme !
Points clés :
✅ Branchement conditionnel avec if-elif-else
✅ Itérer sur des collections avec for
✅ Itération basée sur des conditions avec while
✅ Contrôle avec break, continue, pass
✅ Exemples pratiques (jeux, calculatrice, etc.)
Prochaine étape : Apprenez à rendre le code réutilisable dans Fonctions !