import java.lang.*;
import java.math.*;
import java.util.*;
import java.io.*;
public class Main {
ArrayList<Line> v=new ArrayList<>();
int blocksize=500;
int totalblocks;
ConvexHullTrick cht[];
ArrayList<Line> vec[];
ArrayList<Line> tmpvec=new ArrayList<>();
int n,q;
n=ni();
blocksize
=(int)Math.
sqrt(n
)+1;
totalblocks=n/blocksize+1;
if(n%blocksize==0) totalblocks--;
// pw.println(blocksize+" "+totalblocks);
cht=new ConvexHullTrick[totalblocks];
for(int i=0;i<totalblocks;i++){
cht[i]=new ConvexHullTrick(blocksize);
vec[i]=new ArrayList<>();
}
for(int i=0;i<n;i++) {
long a=ni(),b=ni();
if(a
>100000 || b
>100000) throw new Exception("out of bound");
// cht[i/blocksize].add_line(a,b);
vec
[i
/blocksize
].
add(new Line(a,b
)); }
for(int i=0;i<totalblocks;i++){
tmpvec.clear();
for(Line l
: vec
[i
]) tmpvec.
add(new Line(-l.
a,
-l.
b)); for(Line l
: tmpvec
) cht
[i
].
add_line(l.
a,l.
b); }
q=ni();
int cnt=0;
for(int qu=0;qu<q;qu++) {
int type =ni();
if (type == 1) {
int i1 = ni(), i2 = ni();
int st = 0, ed = 0;
while (i1 > vec[st].size()) {
i1 -= vec[st].size();
st++;
}
while (i2 > vec[ed].size()) {
i2 -= vec[ed].size();
ed++;
}
if (st == ed) {
Line l
= vec
[st
].
remove(i1
- 1); vec[st].add(i2 - 1, l);
} else {
Line l
= vec
[st
].
remove(i1
- 1); vec[ed].add(i2, l);
cht[st]=new ConvexHullTrick(vec[st].size());
cht[ed]=new ConvexHullTrick(vec[ed].size());
tmpvec.clear();
for(Line p
: vec
[st
]) tmpvec.
add(new Line(-p.
a,
-p.
b)); for(Line p
: tmpvec
) cht
[st
].
add_line(p.
a,p.
b); tmpvec.clear();
for(Line p
: vec
[ed
]) tmpvec.
add(new Line(-p.
a,
-p.
b)); for(Line p
: tmpvec
) cht
[ed
].
add_line(p.
a,p.
b);
}
// for(Line l : vec[st]) pw.println(l.a+" "+l.b);
cnt++;
if (cnt == blocksize) {
cnt = 0;
rebuild();
}
} else {
int l = ni(), r =ni() ;
int x = ni();
int st = 0, ed = 0;
if(x
>100000) throw new Exception("out of bound");
while (l > vec[st].size()) {
l -= vec[st].size();
st++;
}
while (r > vec[ed].size()) {
r -= vec[ed].size();
ed++;
}
// pw.println(st+" "+ed+" "+l+" "+r);
long ans
= Long.
MIN_VALUE; // pw.println(st+" "+ed);
if(st==ed){
for(int i=l-1;i<r;i++) {
ans
=Math.
max(ans,p.
get(x
)); }
}else {
for (int i
= st
+ 1; i
< ed
; i
++) ans
= Math.
max(ans,
-cht
[i
].
querry(x
)); for (int i = l - 1; i < vec[st].size(); i++) {
ans
= Math.
max(ans, p.
get(x
)); }
for (int i = 0; i < r; i++) {
ans
= Math.
max(ans, p.
get(x
)); }
}
pw.println(ans);
}
}
}
void rebuild(){
v.clear();
for(int i=0;i<totalblocks;i++) cht[i]=new ConvexHullTrick(blocksize);
for(int i=0;i<totalblocks;i++){
v.addAll(vec[i]);
vec[i].clear();
}
for(int i=0;i<v.size();i++){
vec
[i
/blocksize
].
add(new Line(l.
a,l.
b));
}
for(int i=0;i<totalblocks;i++){
tmpvec.clear();
for(Line l
: vec
[i
]) tmpvec.
add(new Line(-l.
a,
-l.
b)); for(Line l
: tmpvec
) cht
[i
].
add_line(l.
a,l.
b); }
}
static class ConvexHullTrick {
int size;
public ConvexHullTrick(int len){
size=0;
// lines=new Line[len];
}
boolean isbad(int prev,int curr,int next){
Line l1
=hull
[prev
],l2
=hull
[curr
],l3
=hull
[next
]; // if((l1.b-l3.b)>Long.MAX_VALUE/(l2.a-l1.a) || (l1.b-l2.b)>Long.MAX_VALUE/(l3.a-l1.a) ){
// return ((l1.b-l3.b)*1.0)/(l3.a-l1.a) <=((l1.b-l2.b)*1.0)/(l2.a-l1.a);
// }
return (double)(l1.b-l3.b)*(l2.a-l1.a)<=(double)(l1.b-l2.b)*(l3.a-l1.a);
}
void add_line(long a,long b){
if(size!=0 && hull[size-1].a==a) return;
hull
[size
++]=new Line(a,b
); while(size>2 && isbad(size-3,size-2,size-1)){
hull[size-2]=hull[size-1];
size--;
}
}
void add_lines(){
Arrays.
sort(lines,
new Comparator
<Line
>() { @Override
int t
=Long.
compare(t2.
a,t1.
a); if(t!=0) return t;
t
=Long.
compare(t1.
b,t2.
b); return t;
}
});
for(Line l
: lines
) add_line
(l.
a,l.
b); }
long querry(long x){
if(size
==0) return Long.
MAX_VALUE; int l=0,r=size-1;
while(l<=r){
int mid=(l+r)/2;
if(mid>0 && x*(hull[mid-1].a-hull[mid].a)<((hull[mid].b-hull[mid-1].b))){
r=mid-1;
}else if(mid+1<size && x*(hull[mid].a-hull[mid+1].a)>((hull[mid+1].b-hull[mid].b))){
l=mid+1;
}else {
ans
=Math.
min(ans,hull
[mid
].
get(x
)); break;
}
}
return ans;
}
}
static class Line implements Comparable
<Line
>{ long a;
long b;
public Line(long a,
long b
){ this.a=a;
this.b=b;
}
long get(long x){
return a*x+b;
}
public int compareTo
(Line c
){ int t
=Long.
compare(c.
a,
this.
a); if(t!=0) return t;
t
=Long.
compare(this.
b,c.
b); return t;
}
}
static class Line2 {
long a;
long b;
int id;
public Line2(int id,long a,long b){
this.a=a;
this.b=b;
this.id=id;
}
long get(long x){
return a*x+b;
}
}
static int randInt(int min,int max){
int randInt=rand.nextInt((max-min)+1)+min;
return randInt;
}
long M= (long)1e9+7;
long s
= System.
currentTimeMillis(); solve();
pw.flush();
if(!INPUT.
isEmpty())tr
(System.
currentTimeMillis()-s
+"ms");
}
public static void main
(String[] args
) throws Exception { new Main
().
run(); }
private byte[] inbuf = new byte[1024];
public int lenbuf = 0, ptrbuf = 0;
private int readByte() {
if(lenbuf == -1)throw new InputMismatchException();
if(ptrbuf >= lenbuf){
ptrbuf = 0;
try { lenbuf
= is.
read(inbuf
); } catch (IOException e
) { throw new InputMismatchException
(); } if(lenbuf <= 0)return -1;
}
return inbuf[ptrbuf++];
}
private boolean isSpaceChar(int c) { return !(c >= 33 && c <= 126); }
private int skip() { int b; while((b = readByte()) != -1 && isSpaceChar(b)); return b; }
private double nd
() { return Double.
parseDouble(ns
()); } private char nc() { return (char)skip(); }
int b = skip();
StringBuilder sb = new StringBuilder();
while(!(isSpaceChar(b))){ // when nextLine, (isSpaceChar(b) && b != ' ')
sb.appendCodePoint(b);
b = readByte();
}
return sb.toString();
}
private char[] ns(int n) {
char[] buf = new char[n];
int b = skip(), p = 0;
while(p < n && !(isSpaceChar(b))){
buf[p++] = (char)b;
b = readByte();
}
return n
== p
? buf
: Arrays.
copyOf(buf, p
); }
private char[][] nm(int n, int m) {
char[][] map = new char[n][];
for(int i = 0;i < n;i++)map[i] = ns(m);
return map;
}
private int[] na(int n) {
int[] a = new int[n];
for(int i = 0;i < n;i++)a[i] = ni();
return a;
}
private int ni() {
int num = 0, b;
boolean minus = false;
while((b = readByte()) != -1 && !((b >= '0' && b <= '9') || b == '-'));
if(b == '-'){
minus = true;
b = readByte();
}
while(true){
if(b >= '0' && b <= '9'){
num = num * 10 + (b - '0');
}else{
return minus ? -num : num;
}
b = readByte();
}
}
private long nl() {
long num = 0;
int b;
boolean minus = false;
while((b = readByte()) != -1 && !((b >= '0' && b <= '9') || b == '-'));
if(b == '-'){
minus = true;
b = readByte();
}
while(true){
if(b >= '0' && b <= '9'){
num = num * 10 + (b - '0');
}else{
return minus ? -num : num;
}
b = readByte();
}
}
private boolean oj
= System.
getProperty("ONLINE_JUDGE") != null; private void tr
(Object...
o) { if(INPUT.
length() > 0)System.
out.
println(Arrays.
deepToString(o
)); }
}
import java.lang.*;
import java.math.*;
import java.util.*;
import java.io.*;
 
public class Main {
    ArrayList<Line> v=new ArrayList<>();
    int blocksize=500;
    int totalblocks;
    ConvexHullTrick cht[];
    ArrayList<Line> vec[];
 
 
    ArrayList<Line> tmpvec=new ArrayList<>();
    int n,q;
 
    void solve() throws Exception {
        n=ni();
 
        blocksize=(int)Math.sqrt(n)+1;
 
        totalblocks=n/blocksize+1;
        if(n%blocksize==0) totalblocks--;
        //   pw.println(blocksize+" "+totalblocks);
        cht=new ConvexHullTrick[totalblocks];
        vec=new ArrayList[totalblocks];
        for(int i=0;i<totalblocks;i++){
            cht[i]=new ConvexHullTrick(blocksize);
            vec[i]=new ArrayList<>();
        }
 
 
        for(int i=0;i<n;i++) {
            long a=ni(),b=ni();
            if(a>100000 || b>100000) throw new Exception("out of bound");
 
            //  cht[i/blocksize].add_line(a,b);
            vec[i/blocksize].add(new Line(a,b));
        }
        for(int i=0;i<totalblocks;i++){
            tmpvec.clear();
            for(Line l : vec[i]) tmpvec.add(new Line(-l.a,-l.b));
            Collections.sort(tmpvec);
            for(Line l : tmpvec) cht[i].add_line(l.a,l.b);
        }
        q=ni();
 
        int cnt=0;
        for(int qu=0;qu<q;qu++) {
            int type =ni();
 
            if (type == 1) {
                int i1 = ni(), i2 = ni();
                int st = 0, ed = 0;
                while (i1 > vec[st].size()) {
                    i1 -= vec[st].size();
                    st++;
                }
                while (i2 > vec[ed].size()) {
                    i2 -= vec[ed].size();
                    ed++;
                }
                if (st == ed) {
                    Line l = vec[st].remove(i1 - 1);
                    vec[st].add(i2 - 1, l);
 
                } else {
                    Line l = vec[st].remove(i1 - 1);
                    vec[ed].add(i2, l);
 
                    cht[st]=new ConvexHullTrick(vec[st].size());
                    cht[ed]=new ConvexHullTrick(vec[ed].size());
                    tmpvec.clear();
                    for(Line p : vec[st]) tmpvec.add(new Line(-p.a,-p.b));
                    Collections.sort(tmpvec);
                    for(Line p : tmpvec) cht[st].add_line(p.a,p.b);
                    tmpvec.clear();
                    for(Line p : vec[ed]) tmpvec.add(new Line(-p.a,-p.b));
                    Collections.sort(tmpvec);
                    for(Line p : tmpvec) cht[ed].add_line(p.a,p.b);
 
 
                }
                // for(Line l : vec[st]) pw.println(l.a+" "+l.b);
                cnt++;
                if (cnt == blocksize) {
                    cnt = 0;
                    rebuild();
                }
            } else {
                int l = ni(), r =ni() ;
                int x = ni();
                int st = 0, ed = 0;
                if(x>100000) throw new Exception("out of bound");
 
                while (l > vec[st].size()) {
                    l -= vec[st].size();
                    st++;
                }
                while (r > vec[ed].size()) {
                    r -= vec[ed].size();
                    ed++;
                }
                // pw.println(st+" "+ed+" "+l+" "+r);
                long ans = Long.MIN_VALUE;
                //  pw.println(st+" "+ed);
                if(st==ed){
                    for(int i=l-1;i<r;i++) {
                        Line p=vec[st].get(i);
                        ans=Math.max(ans,p.get(x));
                    }
                }else {
                    for (int i = st + 1; i < ed; i++) ans = Math.max(ans, -cht[i].querry(x));
                    for (int i = l - 1; i < vec[st].size(); i++) {
                        Line p = vec[st].get(i);
                        ans = Math.max(ans, p.get(x));
                    }
                    for (int i = 0; i < r; i++) {
                        Line p = vec[ed].get(i);
                        ans = Math.max(ans, p.get(x));
                    }
                }
 
                pw.println(ans);
            }
 
        }
 
 
    }
    void rebuild(){
        v.clear();
        for(int i=0;i<totalblocks;i++) cht[i]=new ConvexHullTrick(blocksize);
        for(int i=0;i<totalblocks;i++){
            v.addAll(vec[i]);
            vec[i].clear();
 
        }
        for(int i=0;i<v.size();i++){
            Line l=v.get(i);
            vec[i/blocksize].add(new Line(l.a,l.b));
 
        }
        for(int i=0;i<totalblocks;i++){
            tmpvec.clear();
            for(Line l : vec[i]) tmpvec.add(new Line(-l.a,-l.b));
            Collections.sort(tmpvec);
            for(Line l : tmpvec) cht[i].add_line(l.a,l.b);
        }
 
 
 
    }
    static class ConvexHullTrick {
        int size;
        Line lines[];
        Line hull[];
 
        public ConvexHullTrick(int len){
            size=0;
            // lines=new Line[len];
            hull=new Line[len];
        }
        boolean isbad(int prev,int curr,int next){
            Line l1=hull[prev],l2=hull[curr],l3=hull[next];
//            if((l1.b-l3.b)>Long.MAX_VALUE/(l2.a-l1.a) || (l1.b-l2.b)>Long.MAX_VALUE/(l3.a-l1.a) ){
//                return  ((l1.b-l3.b)*1.0)/(l3.a-l1.a) <=((l1.b-l2.b)*1.0)/(l2.a-l1.a);
//            }
            return (double)(l1.b-l3.b)*(l2.a-l1.a)<=(double)(l1.b-l2.b)*(l3.a-l1.a);
        }
 
        void add_line(long a,long b){
            if(size!=0 && hull[size-1].a==a) return;
            hull[size++]=new Line(a,b);
            while(size>2 && isbad(size-3,size-2,size-1)){
                hull[size-2]=hull[size-1];
                size--;
            }
        }
        void add_lines(){
            Arrays.sort(lines, new Comparator<Line>() {
                @Override
                public int compare(Line t1, Line t2) {
                    int t=Long.compare(t2.a,t1.a);
                    if(t!=0) return t;
                    t=Long.compare(t1.b,t2.b);
                    return t;
                }
            });
            for(Line l : lines) add_line(l.a,l.b);
        }
        long querry(long x){
 
            if(size==0) return Long.MAX_VALUE;
            int l=0,r=size-1;
            long ans=Long.MAX_VALUE;
 
            while(l<=r){
                int mid=(l+r)/2;
                if(mid>0 && x*(hull[mid-1].a-hull[mid].a)<((hull[mid].b-hull[mid-1].b))){
                    r=mid-1;
                }else if(mid+1<size && x*(hull[mid].a-hull[mid+1].a)>((hull[mid+1].b-hull[mid].b))){
                    l=mid+1;
                }else {
                    ans=Math.min(ans,hull[mid].get(x));
                    break;
                }
            }
 
 
            return ans;
        }
    }
 
    static class Line implements Comparable<Line>{
        long a;
        long b;
        public Line(long a,long b){
            this.a=a;
            this.b=b;
        }
        long get(long x){
            return a*x+b;
        }
        public int compareTo(Line c){
            int t=Long.compare(c.a,this.a);
            if(t!=0) return t;
            t=Long.compare(this.b,c.b);
            return t;
        }
    }
    static class Line2 {
        long a;
        long b;
        int id;
        public Line2(int id,long a,long b){
            this.a=a;
            this.b=b;
            this.id=id;
        }
        long get(long x){
            return a*x+b;
        }
    }
 
    static int randInt(int min,int max){
        Random rand=new Random();
        int randInt=rand.nextInt((max-min)+1)+min;
        return randInt;
    }
 
 
 
 
    long M= (long)1e9+7;
    InputStream is;
    PrintWriter pw;
    String INPUT = "";
    void run() throws Exception {
        is = INPUT.isEmpty() ? System.in : new ByteArrayInputStream(INPUT.getBytes());
        pw = new PrintWriter(System.out);
        long s = System.currentTimeMillis();
        solve();
        pw.flush();
        if(!INPUT.isEmpty())tr(System.currentTimeMillis()-s+"ms");
 
    }
    public static void main(String[] args) throws Exception { new Main().run(); }
 
    private byte[] inbuf = new byte[1024];
    public int lenbuf = 0, ptrbuf = 0;
 
    private int readByte() {
        if(lenbuf == -1)throw new InputMismatchException();
        if(ptrbuf >= lenbuf){
            ptrbuf = 0;
            try { lenbuf = is.read(inbuf); } catch (IOException e) { throw new InputMismatchException(); }
            if(lenbuf <= 0)return -1;
        }
        return inbuf[ptrbuf++];
    }
 
    private boolean isSpaceChar(int c) { return !(c >= 33 && c <= 126); }
    private int skip() { int b; while((b = readByte()) != -1 && isSpaceChar(b)); return b; }
 
    private double nd() { return Double.parseDouble(ns()); }
    private char nc() { return (char)skip(); }
 
    private String ns() {
        int b = skip();
        StringBuilder sb = new StringBuilder();
        while(!(isSpaceChar(b))){ // when nextLine, (isSpaceChar(b) && b != ' ')
            sb.appendCodePoint(b);
            b = readByte();
        }
        return sb.toString();
    }
 
    private char[] ns(int n) {
        char[] buf = new char[n];
        int b = skip(), p = 0;
        while(p < n && !(isSpaceChar(b))){
            buf[p++] = (char)b;
            b = readByte();
        }
        return n == p ? buf : Arrays.copyOf(buf, p);
    }
 
    private char[][] nm(int n, int m) {
        char[][] map = new char[n][];
        for(int i = 0;i < n;i++)map[i] = ns(m);
        return map;
    }
 
    private int[] na(int n) {
        int[] a = new int[n];
        for(int i = 0;i < n;i++)a[i] = ni();
        return a;
    }
 
    private int ni() {
        int num = 0, b;
        boolean minus = false;
        while((b = readByte()) != -1 && !((b >= '0' && b <= '9') || b == '-'));
        if(b == '-'){
            minus = true;
            b = readByte();
        }
 
        while(true){
            if(b >= '0' && b <= '9'){
                num = num * 10 + (b - '0');
            }else{
                return minus ? -num : num;
            }
            b = readByte();
        }
    }
 
    private long nl() {
        long num = 0;
        int b;
        boolean minus = false;
        while((b = readByte()) != -1 && !((b >= '0' && b <= '9') || b == '-'));
        if(b == '-'){
            minus = true;
            b = readByte();
        }
 
        while(true){
            if(b >= '0' && b <= '9'){
                num = num * 10 + (b - '0');
            }else{
                return minus ? -num : num;
            }
            b = readByte();
        }
    }
    private boolean oj = System.getProperty("ONLINE_JUDGE") != null;
    private void tr(Object... o) { if(INPUT.length() > 0)System.out.println(Arrays.deepToString(o)); }
 
} 