Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.92/13: Рейтинг темы: голосов - 13, средняя оценка - 4.92
0 / 0 / 0
Регистрация: 10.05.2017
Сообщений: 2
1

Задача Флавия

10.05.2017, 07:47. Показов 2725. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Задача Иосифа-Флавия.По кругу располагается n человек.Ведущий считает по кругу,начиная с первого,и выводи т('казнить') m-го человека.Круг смыкается,счет возобновляется со следующего после 'казненного'.Так продолжается пока в живых останется только один человек.Найти номер оставшегося в живых человека,а также для заданного n найти такое m>1 при котором в живых останется первый.
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
10.05.2017, 07:47
Ответы с готовыми решениями:

Задача Иосифа Флавия
Здравствуйте! Пытаясь ответить на вопрос одного из пользователей данного форума, решил в лоб...

Задача Йосифа флавия
Кто может помочь не могу дойти до этого сам , надо зделать поэтапный вывод каждого удаленного...

Задача Иосифа Флавия
Всем привет. Помогите пожалуйста с этой задачей. Никак допедрить не могу. вот код: ...

Задача иосифа флавия
N человек играют в следующую игру: стоя в кругу они начинают считалку. Счёт идёт до числа M....

2
с++
1282 / 523 / 225
Регистрация: 15.07.2015
Сообщений: 2,562
10.05.2017, 09:29 2
Лучший ответ Сообщение было отмечено tit1206 как решение

Решение

C++
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#include <stdio.h>
 
void PrintWarriors( int* war, int n ) {
 
   int i ;
 
   for ( i = 0; i < n; i++ )
      printf( "%3d", war[i] ) ;
   printf( "\n" ) ;
 
}
 
 
int GetNextWarriorToKill( int* war, int jLastKilled, int n, int k ) {
   
   int   jToKill = jLastKilled + 1 ,
         kLive = 1 ;
 
   do {
      if ( jToKill == n )
         jToKill = 0 ;
      else {
         if (war[jToKill++] == 0 ) 
            ++kLive ;
      }
   } while ( kLive <= k ) ;
 
   return jToKill-1 ;
 
}
 
 
 
int main() {
 
   const int n = 10,
             k =  3 ;
   int   i, 
         jLastKilled = -1 ,
         jToKill ,
         nKilled = 0;
   int   war[1000] ;
 
   for ( i = 0; i < n; i++ )
      war[i] = 0 ;
 
   while ( nKilled < n-1 ) {
      jToKill = GetNextWarriorToKill( war, jLastKilled, n, k ) ;
      war[jToKill] = ++nKilled ;
      jLastKilled = jToKill ;
      PrintWarriors( war, n ) ;
   }
   PrintWarriors( war, n ) ;
 
   for ( i = 0; i < n, war[i] != 0; i++ ) 
      ;
   printf( "The last warrior has #%d (counting from 1)\n", i+1 ) ;
 
   return 0 ;
 
}
0
0 / 0 / 0
Регистрация: 10.05.2017
Сообщений: 2
10.05.2017, 18:02  [ТС] 3
а можно попросить подробное описание вдруг я чего не понял
0
10.05.2017, 18:02
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
10.05.2017, 18:02
Помогаю со студенческими работами здесь

Задача Иосифа Флавия
Здравствуйте. Помогите пожалуйста реализовать такую задачу через списки: По кругу становятся...

Задача Иосифа Флавия, решение циклическим списком
http://andrei-sapeshko.blogspot.ru/2013/04/blog-post.html тут есть пример, но он немного...

Алгоритм нахождения главного элемента из списка (задача Иосифа Флавия)
Выписал алгоритм,называется ф-ция Иосифа. Смысл такой,что N=9 M=5 . Допустим есть 9 человек в...

Задача Иосифа Флавия. Удалить каждый второй элемент из списка и в конце вывести на экран последний оставшийся элемент
Создать циклический список, в котором находятся элементы от 1 до N. Нужно написать программу,...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru