**Problem Description**

Xiaoming, a physical education teacher, would line up the students in his class in order. He first asked the students to arrange them in order from small to large, with the small numbers in front, and then made multiple adjustments. One adjustment Xiaoming may let a classmate out of the team, move forward or backward some distance before inserting into the queue.

For example, a set of mobile examples is given below. The number of students in the example is eight.

0) The student numbers in the initial queue are 1, 2, 3, 4, 5, 6, 7, 8 in turn;

1) For the first adjustment, the command is "Move No. 3 Student 2 Backward", which means that No. 3 Student is out of the team, move the distance of 2 students backward, and then insert it into the queue. The student number of the new queue is 1 , 2, 4, 5, 3, 6, 7, 8;

2) The second adjustment, the command is "No. 8 students move forward 3", which means that No. 8 students leave the team, move the distance of 3 students forward, and then insert them into the queue. The student numbers in the new queue are 1 in order. , 2, 4, 5, 8, 3, 6, 7;

3) The third adjustment, the command is "No. 3 students move forward 2", which means that No. 3 students leave the team, move forward the distance of 2 students, and then insert them into the queue. The student numbers in the new queue are 1 in order. , 2, 4, 3, 5, 8, 6, 7.

Xiao Ming has recorded all the adjustments. What is the student number of all the students from front to back?

Please note in particular that the numbers involved in the above move refer to student numbers, not their position in the team. When moving backward, the moving distance does not exceed the number of people behind the corresponding classmate. If the moving distance is exactly equal to the number of people behind the corresponding classmate, the student will move to the end of the queue. When moving forward, the moving distance does not exceed the number of people in front of the corresponding classmate. If the distance of forward movement is exactly equal to the number of people in front of the corresponding classmate, the student will move to the front of the queue.

For example, a set of mobile examples is given below. The number of students in the example is eight.

0) The student numbers in the initial queue are 1, 2, 3, 4, 5, 6, 7, 8 in turn;

1) For the first adjustment, the command is "Move No. 3 Student 2 Backward", which means that No. 3 Student is out of the team, move the distance of 2 students backward, and then insert it into the queue. The student number of the new queue is 1 , 2, 4, 5, 3, 6, 7, 8;

2) The second adjustment, the command is "No. 8 students move forward 3", which means that No. 8 students leave the team, move the distance of 3 students forward, and then insert them into the queue. The student numbers in the new queue are 1 in order. , 2, 4, 5, 8, 3, 6, 7;

3) The third adjustment, the command is "No. 3 students move forward 2", which means that No. 3 students leave the team, move forward the distance of 2 students, and then insert them into the queue. The student numbers in the new queue are 1 in order. , 2, 4, 3, 5, 8, 6, 7.

Xiao Ming has recorded all the adjustments. What is the student number of all the students from front to back?

Please note in particular that the numbers involved in the above move refer to student numbers, not their position in the team. When moving backward, the moving distance does not exceed the number of people behind the corresponding classmate. If the moving distance is exactly equal to the number of people behind the corresponding classmate, the student will move to the end of the queue. When moving forward, the moving distance does not exceed the number of people in front of the corresponding classmate. If the distance of forward movement is exactly equal to the number of people in front of the corresponding classmate, the student will move to the front of the queue.

Input format

The first line of the input contains an integer

The second line contains an integer

The next m lines are two integers p, q. If q is positive, it means that the student with the student number p moves backward q. If q is negative, it means that the student with the student number p moves forward -q.

*n*, which represents the number of students. The student numbers are numbered from 1 to*n*.The second line contains an integer

*m*that represents the number of adjustments.The next m lines are two integers p, q. If q is positive, it means that the student with the student number p moves backward q. If q is negative, it means that the student with the student number p moves forward -q.

Output format

Output a line containing n integers, separated by a space between two adjacent integers, representing the student numbers of all students from front to back.

**Sample input**

8

3

3 2

8 -3

3 -2

3

3 2

8 -3

3 -2

**Sample output**

1 2 4 3 5 8 6 7

**Evaluation use case size and agreement**

For all evaluation use cases, 1 ≤

*n*≤ 1000, 1 ≤*m*≤ 1000, all movements are legal.**Full mark code:**

#include<stdio.h> 1 #include <stdio.h> int main() 2 int main () { 3 { int n= 0 ,time,number,location,temp,temp1,i,j,sin= 0 ; // time为做几次调整 4 int n = 0 , time, number, location, temp, temp1, i, j, sin = 0 ; // time is adjusted several times scanf( " %d %d " ,&n,& time); 5 scanf ( " % d% d " , & n, & time); int a[n]; 6 int a [n]; for (i= 0 ;i<n;i++ ) 7 for (i = 0 ; i <n; i ++ ) a[i]=i+ 1 ; 8 a [i] = i + 1 ; while ( 1 ) 9 while ( 1 ) { 10 { scanf( " %d %d " ,&number,& location); 11 scanf ( " % d% d " , & number, & location); for (j= 0 ;j<n;j++ ) 12 for (j = 0 ; j <n; j ++ ) if (a[j]== number) 13 if (a [j] == number) break ; 14 break ; temp= a[j]; 15 temp = a [j]; if (location< 0 ) // 往前移 16 if (location < 0 ) // forward { 17 { for (i=j;i>- 1 ;i-- ) 18 for (i = j; i> -1 ; i-- ) { 19 { a[i]=a[i- 1 ]; 20 a [i] = a [i- 1 ]; temp1=temp1+ 1 ; 21 temp1 = temp1 + 1 ; if (temp1==(- location)) 22 if (temp1 == ( -location)) break ; 23 break ; } 24 } a[j+location]= temp; 25 a [j + location] = temp; } 26 } else // 往后移 27 else // Move backward { 28 { for (i=j;i<n;i++ ) 29 for (i = j; i <n; i ++ ) { 30 { a[i]=a[i+ 1 ]; 31 a [i] = a [i + 1 ]; temp1=temp1+ 1 ; 32 temp1 = temp1 + 1 ; if (temp1== location) 33 if (temp1 == location) break ; 34 break ; } 35 } a[j+location]= temp; 36 a [j + location] = temp; } 37 } sin=sin+ 1 ; 38 sin = sin + 1 ; temp=temp1= 0 ; 39 temp = temp1 = 0 ; if (sin== time) 40 if (sin == time) break ; 41 break ; 42 } 43 } for (i= 0 ;i<n;i++ ) 44 for (i = 0 ; i <n; i ++ ) printf( " %d " ,a[i]); 45 printf ( " % d " , a [i]); return 0 ; 46 return 0 ; 47 } 48 }