1 / 1 / 0
Регистрация: 13.02.2015
Сообщений: 30
|
|
1 | |
Вывод определенной цифры в числовой последовательности22.09.2016, 08:12. Показов 7262. Ответов 36
Метки нет (Все метки)
Доброе утро форумчане, решал задачки для бегинеров на c++ и столкнулся с задачей, до которой никак не могу допереть.
Пользователь вводит натуральное k с клавиатуры, программа выводит k-ую цифру(именно цифру), из последовательности квадратов натуральных чисел вида 1491625.... Не могу допереть, прошу вашей помощи, если можно с комментариями.
0
|
22.09.2016, 08:12 | |
Ответы с готовыми решениями:
36
Вычислить сумму элементов числовой последовательности, в записи значения которых содержится две разные цифры Вычислить среднее арифметическое значение элементов числовой последовательности, в записи значения которых содержится две различные цифры Вывод определенных чисел из числовой последовательности (!без массива!) Вывод матрицы в Си в определенной последовательности |
Неэпический
|
||||||
22.09.2016, 15:09 | 21 | |||||
Таблицы, так таблицы.
2
|
Объявлятель переменных
1220 / 406 / 320
Регистрация: 24.09.2011
Сообщений: 1,265
|
|
22.09.2016, 15:43 | 25 |
Apostol584 тоже вполне работоспособный код выложил.
Croessmah, откуда переменная num в 16-й строке?
1
|
22.09.2016, 15:48 | 26 |
Он выложил хрень
1
|
Неэпический
|
|||||||||||
22.09.2016, 15:56 | 27 | ||||||||||
Видимо, вылетела при редактировании поста.
Добавлено через 6 минут
3
|
Объявлятель переменных
1220 / 406 / 320
Регистрация: 24.09.2011
Сообщений: 1,265
|
|
22.09.2016, 16:02 | 28 |
Я в курсе. У Байта тоже не зарадуешься, т.к. вычислять квадрат несколько тысяч раз подряд — я извиняюсь.
0
|
22.09.2016, 16:05 | 29 |
Я не вчитывался в алгоритм Байта, я просто
1) не увидел ни одной строки (стринга) в его коде 2) привык доверять его котам Ежу же понятно, что отщипывать от искомого числа количества разрядов последовательных квадратов быстрее и экономнее по памяти, чем костылить через стринги.
1
|
Объявлятель переменных
1220 / 406 / 320
Регистрация: 24.09.2011
Сообщений: 1,265
|
|
22.09.2016, 16:10 | 30 |
Croessmah, где-то баг.
getSymbol(280) должен вернуть 6 , а возвращает 1 . Пруф: http://oeis.org/A001191/b001191.txtP.s. Хотя, быть может, я не ту последовательность проверяю...
0
|
Диссидент
27706 / 17322 / 3812
Регистрация: 24.12.2010
Сообщений: 38,979
|
|
22.09.2016, 16:21 | 31 |
Согласен.
Нужно использовать то, что числа от sqrt(102n) до sqrt(102n+1) дают n+1 знаков и от sqrt(102n+1) до sqrt(102n+2) n+2 знака. И сразу просчитывать вот такие экспотенциальные куски.
0
|
Неэпический
|
|||||||||||
22.09.2016, 16:25 | 32 | ||||||||||
Решение в лоб:
Видимо, Вы не учли, что в моей программе индексы берутся с нуля, у ТС в задаче с 1, но этим заморачиваться я не желаю, но всё же в функции getSymbol я сделал поправочку
Уберите комменты и будет 6. И да, на самых последних индексах провести тест не могу, так что сделать ограничение индекса сверху тоже не получится.
0
|
Неэпический
|
|
22.09.2016, 16:32 | 34 |
Так я и высчитывал программно. Или Вы думаете, что я с калькулятором сидел?
Но делать это каждый раз особого смысла нет. Там еще был третий массив, но он в конечной реализации уже был не нужен.
0
|
Объявлятель переменных
1220 / 406 / 320
Регистрация: 24.09.2011
Сообщений: 1,265
|
|
22.09.2016, 16:47 | 35 |
Это да, не учёл. Заметил это только после того, как уже не мог исправить свой пост.
0
|
Неэпический
|
||||||
22.09.2016, 17:15 | 36 | |||||
SpBerkut, я вообще сначала другое решение планировал.
Сделал быстренько, обновил страничку, а Вы уже такое решение выдали. Ну не выкладывать же тоже самое, правда у меня массив поболее был, и я его потом выкинул. Поэтому я решил сразу сделать таблички для кол-ва символов до каждого прибавления символов. Это массив numbersSumCount. Название взято от балды, как у настоящего говнокодера. Оставлю здесь небольшое объяснение работы. Последовательность 149162536496481100121144169196225256289324361400... Массив numbersSumCount: 0, 3, 15, ... numbersSumCount[x] = индекс с которого начинается последовательность (x+1)-значных чисел. numbersSumCount[0] = 0: до (0+1) однозначных чисел не было ни одного символа. numbersSumCount[1] = 3: до (1+1) двузначных чисел находится 3 символа (149). numbersSumCount[2] = 15: до (2+1) трехзначных чисел находится 15 символов (149162536496481). и т.д. Второй массив (seqStartNubmers) это числа с которых квадраты начинают прибавлять в символах. seqStartNubmers[0] = 1:переход квадрата с нуля символов в числе на 1 символ начинается с 1. (1*1=1) seqStartNubmers[1] = 4: (4*4=16) - два символа seqStartNubmers[2] = 10: (10*10=100) - три символа seqStartNubmers[3] = 32: (32*32=1024) - четыре символа и т.д. Можно было хешировать сами квадраты, но я что-то тупанул сначала, а потом лень было.
P.S. Да, объяснять это прям мое. Кто-нибудь что-нибудь понял из написанного?
0
|
22.09.2016, 17:19 | 37 |
Croessmah, да все понятно Просто раз уж такая пьянка, то надо вылезать из детских штанишек 64 размера и переходить в безразмерные взрослые штаны (Ну, или сразу брать языки с такими штанами из коробки )
1
|
22.09.2016, 17:19 | |
22.09.2016, 17:19 | |
Помогаю со студенческими работами здесь
37
Вывод столбцов в определенной последовательности Вывод информации из базы данных в определенной последовательности Вывести значения элементов числовой последовательности, в записи значения которых содержится две одинаковых цифры Вывод k-ой цифры из последовательности натуральных чисел. Вывод числовой последовательности "лесенкой" Признаком конца числовой последовательности является число 0. Найти среднее орифметическое положительных элементов последовательности. Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |