Akash Tawade Ответов: 1

Найдите самый большой палиндром, сделанный из произведения двух 3-значных чисел.


public class prob_4
{

	
	public static void main(String[] args)
	{
		int product = 0;
		int rev = 0;
		int max_product = 0;
		int r;
		
		for(int i=100;i<=999;i++)
		{
			for(int j=101;j<=999;j++)
			{
				
				
				product = i * j;
				
				
				
				if(product < max_product)
				{
					break;
				}
				int number = product;
				
				while(number > 0)
				{
					r =  number % 10;
					rev = (rev * 10) + r;
					number = number/10;
				}
				
				
					if(product == rev && product > max_product)
					{
						max_product = product;
					}
					
					
				}
				
			
			
			
		}

		System.out.println(max_product);
	}

}


Что я уже пробовал:

I am tring my best for solving this question but i got 0 answer after run the code....whats wrong in that code?

Graeme_Grant

Это домашнее задание, шанс для вас показать, что вы понимаете. Разработайте ответ на бумаге, как обычный математический вопрос, а затем преобразуйте его в код.

Чтобы немного помочь вам с вашей программой, вопрос заключается в том, чтобы "найти самый большой". Так не будет ли быстрее работать от наибольшего числа к наименьшему, а не от наименьшего к наибольшему?

Akash Tawade

Я нашел тот же результат и в самом большом и в самом маленьком...

1 Ответов

Рейтинг:
1

Patrice T

Подсказка: 101*101=10201, 111*111=12321
Сначала используйте его для проверки правильности вашего кода для обнаружения палиндромов.
Совет: создание функции ispalindrome() упростит ваш код.

Цитата:
Я проверил свое значение "rev", оно становится странным ... что не так в обратной логике ?

Каково начальное значение rev когда вы переворачиваете число ?
Используйте отладчик, чтобы следить за тем, что вы с ним делаете.

Для целей тестирования измените диапазон значений на 100-112 и используйте отладчик, чтобы увидеть, что на самом деле делает ваш код.
-----
Ваш код ведет себя не так, как вы ожидаете, или вы не понимаете, почему !

Существует почти универсальное решение: запускайте свой код на отладчике шаг за шагом, проверяйте переменные.
Отладчик здесь, чтобы показать вам, что делает ваш код, и ваша задача-сравнить с тем, что он должен делать.
В отладчике нет никакой магии, он не знает, что должен делать ваш код, он не находит ошибок, он просто помогает вам, показывая, что происходит. Когда код не делает того, что ожидается, вы близки к ошибке.
Чтобы увидеть, что делает ваш код: просто установите точку останова и посмотрите, как работает ваш код, отладчик позволит вам выполнять строки 1 на 1 и проверять переменные по мере их выполнения.

Обратная сторона этого решения:
- Это DIY, вы один отслеживаете проблему и находите ее корни, которые ведут к решению.
Положительная сторона этого решения:
- Это также отличный инструмент обучения, потому что он показывает вам реальность, и вы можете увидеть, какие ожидания соответствуют реальности.

Вторичное воздействие
- Вы будете гордиться тем, что сами находите Жуков.
- Ваши навыки обучения улучшатся.

Вы должны довольно быстро найти, что не так.

Отладчик - Википедия, свободная энциклопедия[^]

Освоение отладки в Visual Studio 2010 - руководство для начинающих[^]
Базовая отладка с помощью Visual Studio 2010 - YouTube[^]

http://docs.oracle.com/javase/7/docs/technotes/tools/windows/jdb.html[^]
https://www.jetbrains.com/idea/help/debugging-your-first-java-application.html[^]

Отладчик здесь только для того, чтобы показать вам, что делает ваш код, и ваша задача-сравнить его с тем, что он должен делать.


Akash Tawade

Prob_4 открытый класс
{


публичный статический пустота главный(строка[] аргументы)
{
int product = 0;
int rev = 0;
инт max_product = 0;
int r;



for(int i=100;i<=999;i++)
{
int j = i;

продукт = i * j;
Системы.из.код println(продукт + ""+ я + "" + J на клавиатуре);

если(продукт &ЛТ; max_product)
{
перерыв;
}

int number = продукт;

в то время как(число > 0)
{
r = число % 10;
об = (Об * 10) + р;
число = число/10;
}


если(товар == оборотов и усилитель; & продукта &ГТ; max_product)
{
max_product = продукт;
}


}






Системы.из.код println(max_product);
}

}










Дайте тот же выход, что и 0.

Patrice T

Воспользуйся Улучшить вопрос чтобы обновить ваш вопрос.
Чтобы каждый мог обратить внимание на эту информацию.
и объясните проблемы с кодом.

Akash Tawade

Prob_4 открытый класс
{


публичный статический пустота главный(строка[] аргументы)
{
int product = 0;
int rev = 0;
инт max_product = 0;
int r;



for(int i=100;i<=999;i++)
{
//int j = i;
for(int j=100;j<=999;j++)
{

продукт = i * j;
Системы.из.код println(продукт + ""+ я + "" + J на клавиатуре);

если(продукт &ЛТ; max_product)
{
перерыв;
}

int number = продукт;

в то время как(число != 0)
{
r = число % 10;
об = (Об * 10) + р;
число = число/10;

}

Системы.из.код println(откр.);

если(товар == оборотов и усилитель; & продукта &ГТ; max_product)
{
max_product = продукт;
}

}
}






Системы.из.код println(max_product);
}

}






Я проверил свое значение "rev", оно становится странным ... что не так в обратной логике ?