-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrange_palindrome.java
More file actions
62 lines (52 loc) · 2.08 KB
/
range_palindrome.java
File metadata and controls
62 lines (52 loc) · 2.08 KB
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
50
51
52
53
54
55
56
57
58
59
60
61
62
package Sources;
import java.io.PrintWriter;
import java.util.Scanner;
public class range_palindrome{
public static void main(String [] args){
Scanner bt = new Scanner( System.in );
PrintWriter w = new PrintWriter( System.out,true );
int lower = bt.nextInt();int upper = bt.nextInt();
String limit = upper + "";
int upperDigits = limit.length();
limit = lower + "";
int lowerDigits = limit.length();
for(int i = lowerDigits;i <= upperDigits;i++){
if(i%2 == 0) even(i,lower,upper);
else odd(i,lower,upper);
}
w.println();
bt.close();
w.close();
}
public static void even(int digits,int lower,int upper){
int half = digits / 2;
int lowerLimit,upperLimit;
lowerLimit = (int)Math.pow(10,half - 1);
upperLimit = (int)(Math.pow(10,half) - 1);
for(int i = lowerLimit;i <= upperLimit;i++){
String number = i + "";
StringBuffer sb = new StringBuffer(number).reverse();
number += sb.toString();
int num = Integer.parseInt(number);
if(num >= lower && num <= upper) System.out.print(num + " ");
if(num > upper) break;
}
}
public static void odd(int digits,int lower,int upper){
int half = (int)(digits / 2);
int lowerLimit,upperLimit;
lowerLimit = (int)Math.pow(10,half - 1);
upperLimit = (int)(Math.pow(10,half) - 1);
for(int i = lowerLimit;i <= upperLimit;i++){
for(int middle = 0;middle <= 9;middle++){
String number = i + "";
StringBuffer sb = new StringBuffer(number).reverse();
number += middle + "";
number += sb.toString();
int num = Integer.parseInt(number);
if(num >= lower && num <= upper) System.out.print(num + " ");
if(num > upper) break;
}
}
}
}