IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> число N можно представить в виде 2 квадратов?, циклы
DruiD
сообщение 5.10.2006 19:21
Сообщение #1


Новичок
*

Группа: Пользователи
Сообщений: 31
Пол: Мужской
Реальное имя: Андрей

Репутация: -  0  +


Дано число n . Возможно ли записать его в виде суммы 2 квадратов натуральных чисел? blink.gif

Сообщение отредактировано: DruiD - 5.10.2006 19:26
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
Lapp
сообщение 6.10.2006 6:02
Сообщение #2


Уникум
*******

Группа: Модераторы
Сообщений: 6 823
Пол: Мужской
Реальное имя: Лопáрь (Андрей)

Репутация: -  159  +


Цитата(мисс_граффити @ 5.10.2006 22:54) *

кроме того, условие достаточное, но не необходимое. (у нас же не сказано, что числа разные. так что 8 ...
ряд можно продолжить

.. до бесконечности yes2.gif . Да любая сумма квадратов одинаковой четности сразу выпадает..
Цитата(мисс_граффити @ 5.10.2006 22:54) *

что-то типа

Во-первых, в условии нет указания, что одно из чисел не должно быть нулем, так что проверка b на равенство нулю не нужна.
Во-вторых, проверка типа real на равенство нулю не годится... sad.gif
Я бы был проще и вообще постарался избежать извлечений корня. Типа так:
Код
var
  N,i,j:integer;
begin
  Write('Number? ');ReadLn(N);
  for i:=1 to N do for j:=i to N do if N=i*i+j*j then
    WriteLn(N,' = ',i,'^2 + ',j,'^2');
  WriteLn('Over');
  ReadLn;
end.

Код, конечно, крайне неоптимальный. Первое, что можно сделать - запоминать значение i*i. Затем - лучше ограничить циклы. Можно и квадраты запоминать в массив..
Вот первый шаг по оптимизации:
Код
var
  N,i,ii,j,m:integer;
begin
  Write('Number? ');ReadLn(N);
  m:=N div 2+1;
  for i:=1 to m do begin
    ii:=i*i;
    for j:=i to m do if N=ii+j*j then WriteLn(N,' = ',i,'^2 + ',j,'^2');
  end;
  WriteLn('Over');
  ReadLn;
end.

Думаю, остается еще громадный простор для полета мысли.. smile.gif


--------------------
я - ветер, я северный холодный ветер
я час расставанья, я год возвращенья домой
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

Сообщений в этой теме
DruiD   число N можно представить в виде 2 квадратов?   5.10.2006 19:21
volvo   Проверяй, подходит ли данное тебе число под это ус...   5.10.2006 19:30
мисс_граффити   Проверяй, подходит ли данное тебе число под это у...   7.10.2006 13:25
мисс_граффити   я думаю, тут задача на другое... именно на циклы -...   5.10.2006 21:54
lapp   кроме того, условие достаточное, но не необходимо...   6.10.2006 6:02
мисс_граффити   Во-первых, в условии нет указания, что одно из чи...   6.10.2006 20:17
volvo   Ну, тогда и цикл for i:=1 to m do begin ii:=...   6.10.2006 10:41
volvo   Юля, не торопись искать этот учебник. В русской ма...   6.10.2006 20:44
мисс_граффити   Юля, не торопись искать этот учебник. В русской м...   6.10.2006 21:41
lapp   Я всегда считал (как меня учили), что натуральные ...   7.10.2006 0:41
мисс_граффити   Но, согласись, что с точки зрения использования ц...   7.10.2006 10:06
volvo   мисс_граффити :blink: :blink: А какое натурально...   7.10.2006 13:36
мисс_граффити   мисс_граффити :blink: :blink: А какое натуральн...   7.10.2006 13:42
volvo   Sorry, это касаемо только ПРОСТЫХ нечетных чисел.....   7.10.2006 13:52


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 12.08.2025 6:20
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"