![]() |
Здравствуйте, гость ( Вход | Регистрация )
![]() |
InFuz |
![]()
Сообщение
#1
|
Студент ![]() ![]() Группа: Продвинутые Сообщений: 116 Регистрация: 13.10.2009 Город: Ульяновск Учебное заведение: УлГУ Вы: студент ![]() |
Задача: Удалить из массива числа, которые являются полным квадратом и имеют нечетную сумму цифр.
Условие: Массив целоцисленный от -32000 до 32000. (ни каких real (IMG:style_emoticons/default/smile.gif) ). Массив вводится в другой процедуре и есть M:mas, N-длина массива. Моя процедура которая чот не батрачит )) procedure Work (var M:mas; N:integer); var i,b,sym,ost:integer; f:boolean; begin for i:=1 to N do begin f:=true; sym:=0; ost:=0; b:=m[i]; while b=0 do begin ost:=b mod 10; sym:=sym + ost; b:=b div 10; end; if sym mod 2=0 then f:=false; if (f=true) and (sqrt(m[i]) in integer) then m[i]:=m[i+1]; end; end; |
![]() ![]() |
InFuz |
![]()
Сообщение
#2
|
Студент ![]() ![]() Группа: Продвинутые Сообщений: 116 Регистрация: 13.10.2009 Город: Ульяновск Учебное заведение: УлГУ Вы: студент ![]() |
Извиняюсь за тупость (IMG:style_emoticons/default/blush.gif) , но вроде for i:=i to N do правильно, при нахождении удаляемого элемента нет нужды заводить цикл со значениями i которые меньше его текушего значения.
В сдвиге вынес N:=N-1 за цикл for а то она массив обрезала N-i раз, а надо было только один. Но ошибку все равно выдает. program Masiv; uses crt; const Nmax=16; type mas= array [1..Nmax] of integer; var G,M:mas; var N:integer; procedure Enter (var M:mas; Nmax:integer; var N:integer); var i,x:integer; begin N:=0; for i:=1 to Nmax do begin write ('M[',i,']='); readln (x); if x=0 then break; inc (N); M[i]:=x; end; end; procedure Print (var M:mas; N:integer); var i:integer; begin for i:=1 to N do write (M[i],'; '); writeln; end; procedure Work (var M:mas; var G:mas; N:integer); var j,i,b,sym,ost:integer; f,q:boolean; begin for j:=1 to 178 do G[j]:=j*j; for i:=1 to N do begin f:=true; sym:=0; ost:=0; q:=false; b:=m[i]; for j:=1 to 178 do begin if g[j]=m[i] then begin q:=true; break; end; end; repeat ost:=b mod 10; sym:=sym + ost; b:=b div 10; until b=0; if sym mod 2=0 then f:=false; if (f=true) and (q=true) then begin for i:=i to N do m[i]:=m[i+1]; N:=N-1; end; end; end; Begin clrscr; Enter (M,Nmax,N); Print (M,N); Work (M,G,N); Print (M,N); readkey End. Помогите, а то в четверг уже надо сдавать. (IMG:style_emoticons/default/newconfus.gif) |
![]() ![]() |
![]() |
Текстовая версия | Сейчас: 26.5.2025, 0:03 |
Зеркало сайта Решебник.Ру - reshebnik.org.ru