Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 21.07.2022
Сообщений: 7

Игра угадай число

03.08.2022, 23:34. Показов 840. Ответов 1

Студворк — интернет-сервис помощи студентам
игра угадай число. не могу набить ответы всех участников, то выбивает когда кто-то проиграл, то не вносит в бд и пишет ошибку.
помогите понять в чем проблема.
я должна пройтись всеми участниками, внести в бд результаты, и выбрать 3 победителя. спасибо

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
from random import randint
import sqlite3
 
comp_int = randint(1, 20)
 
with sqlite3.connect('my_db1.db') as con:
    cur = con.cursor()
    cur.execute("""CREATE TABLE IF NOT EXISTS players (
    id INTEGER, 
    name TEXT,
    lives INTEGER
    )""")
    con.commit()
 
    def igra():
        player_list = []
        numb_lives = 0
        while len(player_list) < 6:
            player = input('Введите свое имя:\n')
            while numb_lives < 6:
                user_int = int(input('Введите число: '))
                if comp_int > user_int:
                    print('Компьютер загадал число больше введенного')
                    numb_lives += 1
                elif comp_int < user_int:
                    print('Компьютер загадал число меньше введенного')
                    numb_lives += 1
                else:
                    print(f"Вы угадали, это число {comp_int} !")
                    break
            else:
                print(f'Вы проиграли, это число {comp_int} !')
            player_list += [player]
            player_id = player_list.index(player) + 1
            players = f'{player_id}, {player}, {numb_lives}'
            return players
    print(igra())
    cur.executemany("""INSERT INTO players VALUES (?, ?, ?), players""")
    con.commit()
    cur.execute("""SELECT min(lives) FROM players""")
    three_win = cur.fetchmany(3)
    print(three_win)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.08.2022, 23:34
Ответы с готовыми решениями:

Игра «Угадай число». Программа задает псевдослучайное число из заданного диапазона
Игра «Угадай число». Программа задает псевдослучайное число из заданного диапазона. Диапазон и количество попыток пользователь вводит с ...

Игра угадай число
При угадывании числа все равно пишет что не угадали помогите пожалуйста import random random_namber = random.randint(1, 5) ...

Игра Угадай число
Помогите улучшить алгоритм, который угадывает число и делает это за как можно меньшее число попыток (без читерства). def...

1
2431 / 1474 / 633
Регистрация: 01.11.2021
Сообщений: 2,269
04.08.2022, 00:46
Ошибок много. Примерно так. Но тут еще так же можно чего-нибудь поправить.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
from random import randint
import sqlite3
 
 
def igra():
    players = []
    for i in range(6):
        player = input('Введите свое имя:\n')
        numb_lives = 0
        comp_int = randint(1, 20)
        while numb_lives < 6:
            user_int = int(input('Введите число: '))
            if comp_int > user_int:
                print('Компьютер загадал число больше введенного')
                numb_lives += 1
            elif comp_int < user_int:
                print('Компьютер загадал число меньше введенного')
                numb_lives += 1
            else:
                print(f"Вы угадали, это число {comp_int} !")
                break
        else:
            print(f'Вы проиграли, это число {comp_int} !')
        players.append((player, numb_lives))
    return players
 
 
with sqlite3.connect('my_db1.db') as con:
    cur = con.cursor()
    cur.execute("""CREATE TABLE IF NOT EXISTS players (
    id INTEGER PRIMARY KEY, 
    name TEXT,
    lives INTEGER
    )""")
    con.commit()
 
users = igra()
sql = """INSERT INTO players(name, lives) VALUES (?, ?);"""
cur.executemany(sql, users)
con.commit()
cur.execute("""SELECT name FROM players WHERE lives = (SELECT MIN(lives) FROM players) """)
three_win = cur.fetchmany(3)
print(three_win)
Добавлено через 1 минуту
Подправил немного.
Таблицу в БД надо пересоздать только.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
04.08.2022, 00:46
Помогаю со студенческими работами здесь

Игра Угадай число
Я создаю текстовую игру на Python. Цель такова: Компьютер загадывает число от 1 до 100, и игрок должен угадать число. Если игрок...

Игра «Угадай число с одной попытки»
Написать программу проверки знания дат основания городов: СанктПетербурга, Москвы и Ельца с подсчетом общего количества очков. В случае ...

Игра "Угадай число - Экстрасенс" Не получается реализовать новую игру с генерацией нового числа
Игра &quot;Угадай число - Экстрасенс&quot; Не получается реализовать новую игру с генерацией нового числа по нажатию кнопки &quot;новая игра&quot; ...

Игра "Угадай число"
Игра на питоне которая спрашивает у тебя число и саса угадывает, записываю те числа которые называет.

Игра "угадай число"
Цель: написать игрушку &quot;Угадай число&quot;. Условия: Допустимые значения от 1 до 99 включительно. Подсчёт попыток игрока. Подсказка...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru