알고리즘/Java
[SWEA] 9659 다항식 계산
세진짱
2020. 4. 3. 20:29
문제를 푸는것보다 이해하는게 더 어려운 문제같다
문제를 풀려면 그냥 쓰여져있는대로 코딩하면 된다!
하라는대로!!
a와 b가 i-1이하기 때문에 무조건 이전에 계산한 식을 통해 값을 구할 수 있다
그럼 for문을 통해 N-1개의 값들을 먼저 저장하고 그걸 이용해서 f(x)값을 구해보자!
소스코드
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
|
public class Solution {
static class Node {
int tx,ax,bx;
Node(int _tx,int _ax,int _bx){
this.tx=_tx;
this.ax=_ax;
this.bx=_bx;
}
}
public static final long mod = 998244353;
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int t = sc.nextInt();
for(int tc=1;tc<=t;tc++) {
int n = sc.nextInt();
Node[] arr = new Node[n+1];
for(int i=2;i<=n;i++) {
int tx = sc.nextInt();
int ax = sc.nextInt();
int bx = sc.nextInt();
Node nNode = new Node(tx,ax,bx);
arr[i]=nNode;
}
int m = sc.nextInt();
long[] ans = new long[m+1];
for(int i=0;i<m;i++) {
int x = sc.nextInt();
long[] num = new long[n+1];
num[0]=1; num[1]=x;
for(int j=2;j<=n;j++) {
if(arr[j].tx==1) num[j] = num[arr[j].ax]+num[arr[j].bx];
else if(arr[j].tx==2) num[j]=arr[j].ax*num[arr[j].bx];
else num[j]=num[arr[j].ax]*num[arr[j].bx];
num[j]%=mod;
}
ans[i]=num[n];
}
System.out.print("#"+tc+" ");
for(int j=0;j<m;j++) System.out.print(ans[j]+" ");
System.out.println();
}
}
}
|