1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
| DruiD |
5.10.2006 19:21
Сообщение
#1
|
![]() Новичок ![]() Группа: Пользователи Сообщений: 31 Пол: Мужской Реальное имя: Андрей Репутация: 0 |
Дано число n . Возможно ли записать его в виде суммы 2 квадратов натуральных чисел?
Сообщение отредактировано: DruiD - 5.10.2006 19:26 |
![]() ![]() |
| Lapp |
6.10.2006 6:02
Сообщение
#2
|
![]() Уникум ![]() ![]() ![]() ![]() ![]() ![]() ![]() Группа: Модераторы Сообщений: 6 823 Пол: Мужской Реальное имя: Лопáрь (Андрей) Репутация: 159 |
кроме того, условие достаточное, но не необходимое. (у нас же не сказано, что числа разные. так что 8 ... ряд можно продолжить .. до бесконечности что-то типа Во-первых, в условии нет указания, что одно из чисел не должно быть нулем, так что проверка b на равенство нулю не нужна. Во-вторых, проверка типа real на равенство нулю не годится... Я бы был проще и вообще постарался избежать извлечений корня. Типа так: Код 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. Думаю, остается еще громадный простор для полета мысли.. -------------------- я - ветер, я северный холодный ветер
я час расставанья, я год возвращенья домой |
DruiD число N можно представить в виде 2 квадратов? 5.10.2006 19:21
volvo Проверяй, подходит ли данное тебе число под это ус... 5.10.2006 19:30
мисс_граффити
Проверяй, подходит ли данное тебе число под это у... 7.10.2006 13:25
мисс_граффити я думаю, тут задача на другое...
именно на циклы -... 5.10.2006 21:54
мисс_граффити
Во-первых, в условии нет указания, что одно из чи... 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![]() ![]() |
|
Текстовая версия | 11.12.2025 3:37 |