2014 dxdy logo

Научный форум dxdy

Математика, Физика, Computer Science, Machine Learning, LaTeX, Механика и Техника, Химия,
Биология и Медицина, Экономика и Финансовая Математика, Гуманитарные науки




Начать новую тему Ответить на тему На страницу Пред.  1 ... 20, 21, 22, 23, 24, 25, 26 ... 54  След.

А вам пакет PARI/GP интересен?
Да 83%  83%  [ 58 ]
Нет 6%  6%  [ 4 ]
Не уверен(а) 11%  11%  [ 8 ]
Всего голосов : 70
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение24.01.2020, 23:01 


05/09/16
12064
Soul Friend в сообщении #1436708 писал(а):
Надо проверить число $n$, что оно не является суммой каких либо элементов вектора $A$.
Есть ли для этого готовая функция на PARI/GP, если нет - то, как это реализовать ?
$n \neq (k_1 + ... + k_i) $
где $k_x$ - элементы множества $A$.


1. $k_x$ -- натуральные, целые, вещественные?
2. Нужно ли думать о какой-то оптимизации (например $i$ чему может быть равно?)

В чём у вас собсно трудность? "Тупой" алгоритм будет генерировать все сочетания из $i$ чисел по $j=1 \dots i$ штук и считать их суммы. Это медленно для вас?

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение25.01.2020, 00:24 
Заслуженный участник


20/08/14
11780
Россия, Москва
Soul Friend
Нечто подобное делал вот здесь (и рядом там посмотрите). Встроенной функции не знаю.
Вы бы уточнили порядок задачи, сколько $n$ надо проверить, длину вектора $A$, их тип, диапазон значений, фиксированы ли они или могут меняться по ходу решения ...

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение25.01.2020, 05:46 
Аватара пользователя


12/10/16
637
Almaty, Kazakhstan
wrest
1) $n, k_x \in \mathbb N$
2) $i$ - не фиксированное значение, ведь надо проверять все $2^m$ комбинации, где $m$ - количество элементов вектора $A$.
Не знаю даже как это тупым перебором сделать, вряд ли это возможно с двумя переменными $i, j$ .

Dmitriy40 в сообщении #1436787 писал(а):
Вы бы уточнили порядок задачи, сколько $n$ надо проверить, длину вектора $A$, их тип, диапазон значений, фиксированы ли они или могут меняться по ходу решения

Много $n$ надо проверять, если $n$ удовлетворяет неравенству, то добавляется к вектору $A$, поэтому количество элементов вектора $A$ растёт со временем.
Возможное решение - создать новый вектор $B$ для записи всех сумм.

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение25.01.2020, 07:55 
Аватара пользователя


12/10/16
637
Almaty, Kazakhstan
Soul Friend в сообщении #1436806 писал(а):
все $2^m$ комбинации

$2^m-m$ комбинации.

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение25.01.2020, 09:31 


05/09/16
12064
Soul Friend в сообщении #1436806 писал(а):
ведь надо проверять все $2^m$ комбинации, где $m$ - количество элементов вектора $A$.
Не знаю даже как это тупым перебором сделать, вряд ли это возможно

В качестве первого шага, запустите вот эти две строчки:
A=[1,8,5,9];
forsubset(#A,x,print("Sum",vecextract(A,x),"=",vecsum(vecextract(A,x))))

Задаются 4 элемента. Генерируются все сочетания от 0 до 4 элементов из этих 4 элементов, вычисляются их (сочетаний) суммы. Магия! :mrgreen:
Теперь запускаем ещё пару строк:
n=14;
forsubset(#A,x,v=vecextract(A,x);if(vecsum(v)==n,print("Sum",v,"=",vecsum(v))))

Результат: печатаются только суммы, равные 14. Черная магия! :mrgreen: :mrgreen:

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение25.01.2020, 12:24 
Аватара пользователя


12/10/16
637
Almaty, Kazakhstan
wrest
Спасибо.
wrest в сообщении #1436816 писал(а):
forsubset(#A,x

означает перебрать $x$ от одного до $\#b$ как я понял?

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение25.01.2020, 12:31 


05/09/16
12064
Soul Friend в сообщении #1436836 писал(а):
означает перебрать $x$ от одного до $\#b$ как я понял?

Нет, не это. Вот тут гляньте https://pari.math.u-bordeaux.fr/dochtml ... ments.html есть описание что делает оператор forsubset.
Это итератор по всем подмножествам множества заданной мощности. При этом имеется в виду, что исходное множество например мощности $n$ -- это множество натуральных чисел от единицы до $n$.
Чтобы нагляднее понять, запустите команду
forsubset(4,x,print(x))

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение26.01.2020, 07:52 
Аватара пользователя


12/10/16
637
Almaty, Kazakhstan
Dmitriy40 в сообщении #1329592 писал(а):
У vecsort есть третий параметр, им можно например исключить дубли

а что это за параметр и как его использовать? Очень надо убрать повторения в векторе, мешают, и код из-за этого выдаёт не то что нужно.
из вектора $b$ надо убрать все повторяющиеся числа которые встречаются в векторе $a$.
Пример:
$b=[1, 3, 5, 1, 3, 3, 3, 9]$
$a=[1, 3, 7, 11, 13]$
результат должен быть:
$b=[5, 9]$
У меня получается убрать только первые два числа, в итоге получается $b=[5, 1, 3, 3, 3, 9]$
Набирал:
Код:
for(i=1, #a, b=vecsort(b, , a[i]) )

тоже выдает некий фантастический результат.

upd:
получилось только так:
Код:
b=setminus(vecsort(b), a)

но то ли это?
2) Вот этот код у меня работает на смартфоне, но на компе выдает ошибку:
Код:
forsubset(#a, x, b=concat(b, [vecsum(vecextract(a, x))]))

vecextract: incorrect type in vecextract [mask] (t_POL).

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение26.01.2020, 10:23 


05/09/16
12064
Soul Friend в сообщении #1436954 писал(а):
из вектора $b$ надо убрать все повторяющиеся числа которые встречаются в векторе $a$.
Пример:
$b=[1, 3, 5, 1, 3, 3, 3, 9]$
$a=[1, 3, 7, 11, 13]$
результат должен быть:
$b=[5, 9]$

А если
$b=[1,3,5]$
$a=[2,3,4]$
То какой результат должен быть?

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение26.01.2020, 11:30 
Аватара пользователя


12/10/16
637
Almaty, Kazakhstan
wrest в сообщении #1436961 писал(а):
А если
$b=[1,3,5]$
$a=[2,3,4]$
То какой результат должен быть?

$b=[1,5]$
Подсмотрел на Rozettacode, повторения в самом векторе убираются значением "8" :
Код:
b=vecsort(b, , 8)


Soul Friend в сообщении #1436954 писал(а):
2) Вот этот код у меня работает на смартфоне, но на компе выдает ошибку:
Код:

forsubset(#a, x, b=concat(b, [vecsum(vecextract(a, x))]))


vecextract: incorrect type in vecextract [mask] (t_POL).



Всё ещё не работает, пробовал и вручную набирать, и копипастить, выдает ту же ошибку, хотя на смартфоне работает.

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение26.01.2020, 16:03 


05/09/16
12064
Soul Friend в сообщении #1436964 писал(а):
Всё ещё не работает, пробовал и вручную набирать, и копипастить, выдает ту же ошибку, хотя на смартфоне работает.

Дополните так:
b=[];forsubset(#a, x, print("b=",b," a=",a," x=",x);b=concat(b, [vecsum(vecextract(a, x))]))
Что печатает?

-- 26.01.2020, 16:23 --

Soul Friend в сообщении #1436964 писал(а):
$b=[1,5]$
Подсмотрел на Rozettacode, повторения в самом векторе убираются значением "8" :

Тогда вместо
"из вектора b надо убрать все повторяющиеся числа которые встречаются в векторе a."
вы имеете в виду
"из вектора b надо убрать повторы чисел, а также все числа, которые встречаются в векторе a."
Через множества это делается так:
b=setminus(Set(b),Set(a))
Вообще множества в PARI/GP:
-- всегда упорядочены по возрастанию
-- не имеют повторяющихся элементов
То есть, если вы объединяете множество [1,2,3] и множество [2,3], то получаете множество [1,2,3]
Оператор объединения множеств setunion(x,y)

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение26.01.2020, 16:51 
Аватара пользователя


12/10/16
637
Almaty, Kazakhstan
wrest
Спасибо

wrest в сообщении #1437012 писал(а):
Что печатает?

Всё также выдавала ошибку, переустановил pari/gp, и заработала!

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение09.03.2020, 16:56 


21/05/16
4292
Аделаида
Пару вопросов.
1. Как проверить число на простоту? На целость? На квадратность?
2. Как генерировать примитивные пифогоровы тройки?
3. Как генерировать примитивные пифогоровы тройки с заданым c?

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение09.03.2020, 19:14 


05/09/16
12064
kotenok gav
На прoстоту isprime(n) или ispseudoprime(n) Второе быстрей, но алгоритм вероятностный
На квадратичность issquare(n)
Насчет проверки на целость -- уточните вопрос. Или проверять тип (что он целый) или что дробная часть равна нулю. Второе например так isinteger(x)=if(frac(x)==0,1,0)

О пифагоровых тройках -- ну тут наверное много способов, тема же про калькулятор pari/gp, так что eсли у вас есть алгоритм, поможем с перекладыванием его на pari/gp

 Профиль  
                  
 
 Re: интерактивный курс: введение в программирование на PARI/GP
Сообщение09.03.2020, 20:40 


21/05/16
4292
Аделаида
Так у меня вопрос про пиф. тройки в PARI. Там есть встроенный алгоритм?

 Профиль  
                  
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 810 ]  На страницу Пред.  1 ... 20, 21, 22, 23, 24, 25, 26 ... 54  След.

Модераторы: Karan, Toucan, PAV, maxal, Супермодераторы



Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

Найти:
Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group