import java.util.ArrayDeque; import java.util.Arrays; import java.util.Date; import java.util.Queue; import java.util.Scanner; import java.math.BigInteger; public class main{ public static final BigInteger EIGHT=new BigInteger("8"); public static void main(String[] args){ Scanner sc=new Scanner(System.in); long exec_time=new Date().getTime(); BigInteger n=sc.nextBigInteger(); if(n.compareTo(BigInteger.valueOf(60))<0){ System.out.println(solveNaive(n.intValue())); return; } if(!n.remainder(EIGHT).equals(BigInteger.ONE)||!n.subtract(EIGHT).isProbablePrime(20)){ System.out.println("8"); }else{ System.out.println("14"); } System.err.println(new Date().getTime()-exec_time+"ms"); } public static void check(int x,int n,boolean[] isPrime,boolean[] used,Queue q){ if(x<1||x>n||isPrime[x]||used[x]){ return; } used[x]=true; q.offer(x); } public static int solveNaive(int n){ boolean[] isPrime=isPrimeArray(n); for(int w=1;w<=n;w++){ boolean[] used=new boolean[n+1]; Queue q=new ArrayDeque<>(); used[1]=true; q.offer(1); while(!q.isEmpty()){ int x=q.poll(); if(x%w!=0){ check(x+1,n,isPrime,used,q); } if(x%w!=1){ check(x-1,n,isPrime,used,q); } check(x+w,n,isPrime,used,q); check(x-w,n,isPrime,used,q); } if (used[n]) { return w; } } return -1; } public static boolean[] isPrimeArray(int max){ boolean[] isPrime=new boolean[max+1]; Arrays.fill(isPrime, true); for(int i=2;i*i<=max;i++){ int j=i*2; while(j<=max){ isPrime[j]=false; j+=i; } } return isPrime; } }