2018-06-28 00:24:15 +02:00
|
|
|
import java.util.LinkedList;
|
|
|
|
import java.util.Queue;
|
|
|
|
|
|
|
|
public class Main {
|
|
|
|
|
|
|
|
public static void main(String[] args) {
|
|
|
|
|
|
|
|
String input = args[0];
|
|
|
|
|
|
|
|
String[] parts = input.split(" ");
|
|
|
|
|
|
|
|
// n
|
|
|
|
int mod = Integer.parseInt(parts[0]);
|
|
|
|
//int number = Character.getNumericValue(numberStr.charAt(0));
|
|
|
|
|
|
|
|
String polynomialStr = parts[1];
|
|
|
|
|
|
|
|
// usuwam '[', ']'
|
|
|
|
polynomialStr = polynomialStr.substring(1, polynomialStr.length()-1);
|
|
|
|
|
|
|
|
// ,
|
|
|
|
String[] polynomialNumbers = polynomialStr.split(",");
|
|
|
|
|
|
|
|
LinkedList<Integer> polynomial = new LinkedList<Integer>();
|
|
|
|
|
|
|
|
//test poly
|
|
|
|
LinkedList<Integer> polynomial2 = new LinkedList<Integer>();
|
|
|
|
|
|
|
|
// wypelnienie wielomianu
|
|
|
|
polynomial = fill(polynomialNumbers, polynomial);
|
|
|
|
|
|
|
|
//test
|
|
|
|
LinkedList<LinkedList<Integer>> elements = new LinkedList<LinkedList<Integer>>();
|
|
|
|
elements = createCandidates(polynomial,mod);
|
|
|
|
|
|
|
|
// Idemp
|
|
|
|
System.out.println(idempotent(elements,polynomial,mod));
|
|
|
|
|
|
|
|
//showPoly(polynomial);
|
|
|
|
}
|
|
|
|
|
2018-06-28 00:27:52 +02:00
|
|
|
// wypelnienie wielomianu
|
|
|
|
public static LinkedList<Integer> fill(String[] str, LinkedList<Integer> polynomial){
|
|
|
|
|
|
|
|
for(int i=0; i <str.length; i++) {
|
|
|
|
polynomial.add(Integer.parseInt(str[i]));
|
|
|
|
}
|
|
|
|
|
|
|
|
return polynomial;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static void showPoly(LinkedList<Integer> poly) {
|
|
|
|
System.out.println(poly.toString());
|
|
|
|
}
|
2018-06-28 00:28:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
public static int multiplier(int number, int expect, int mod) {
|
|
|
|
|
|
|
|
/*
|
|
|
|
if(nwd(number,mod) != 1 || nwd(number,mod) != number) {
|
|
|
|
System.out.println("NIE DA SIE");
|
|
|
|
return 0;
|
|
|
|
}*/
|
|
|
|
|
|
|
|
for(int i=1;i<mod;i++) {
|
|
|
|
if(((number*i) % mod) == expect) {
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static LinkedList<Integer> modPolynomial(int mod, LinkedList<Integer> polynomial){
|
|
|
|
|
|
|
|
LinkedList<Integer> result = new LinkedList<Integer>();
|
|
|
|
|
|
|
|
while(!polynomial.isEmpty()) {
|
|
|
|
|
|
|
|
if(polynomial.peek() < 0) {
|
|
|
|
|
|
|
|
result.add(mod + polynomial.poll());
|
|
|
|
}
|
|
|
|
else result.add(polynomial.poll() % mod);
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2018-06-28 00:29:45 +02:00
|
|
|
public static LinkedList<Integer> multiplyPolynomial(LinkedList<Integer> p1, int multiplier){
|
|
|
|
|
|
|
|
LinkedList<Integer> result = new LinkedList<Integer>();
|
|
|
|
|
|
|
|
while(!p1.isEmpty()) {
|
|
|
|
result.add(p1.poll() * multiplier);
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
2018-06-28 00:30:33 +02:00
|
|
|
|
|
|
|
public static LinkedList<Integer> shiftList(LinkedList<Integer> p, int places){
|
|
|
|
|
|
|
|
LinkedList<Integer> result = new LinkedList<Integer>(p);
|
|
|
|
|
|
|
|
if(places == 0) {
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
for(; places>0; places--) {
|
|
|
|
result.addFirst(0);
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static LinkedList<Integer> polynomialsMultiplication(LinkedList<Integer> p1, LinkedList<Integer> p2){
|
|
|
|
|
|
|
|
// suma dlugosci
|
|
|
|
int amount = p1.size() + p2.size();
|
|
|
|
|
|
|
|
// nowy wielomian bedzie dlugosci sumy poteg wyrazow wiodacych obu tablic -1
|
|
|
|
LinkedList<Integer> result = new LinkedList<Integer>();
|
|
|
|
|
|
|
|
for(int i=0;i<amount-1;i++) {
|
|
|
|
result.add(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
// mnozenie
|
|
|
|
for(int i=0; i<p1.size(); i++) {
|
|
|
|
|
|
|
|
for(int j=0; j<p2.size(); j++) {
|
|
|
|
result.set(i+j, (result.get(i+j) + p1.get(i) * p2.get(j)));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
2018-06-28 00:29:45 +02:00
|
|
|
|
2018-06-28 00:30:33 +02:00
|
|
|
}
|
2018-06-28 00:24:15 +02:00
|
|
|
}
|