Все элементы будут равны единице. Сначала они будут заполнены значением, большим своего индекса на 1, а потом каждому элементу, начиная со второго (который А[1]) будет присвоено значение предыдущего элемента и 1 распространится везде.
Для проверки была написана программа с отладочной выдачей.
var a:array[0..10] of integer; i:integer; begin for i:=0 to 10 do begin a[i]:=i+1; Write(a[i],' ') end; Writeln; Write(a[0],' '); for i:=1 to 10 do begin a[i]:=a[i-1]; Write(a[i],' ') end end.
#include <iostream> #include <string> using namespace std;
void DeleteStr(string&, int, int);
int main(void) {string s; int n,l; cin>>s>>n>>l; DeleteStr(s,n,l); cout<<s<<endl; return 0;}
void DeleteStr(string &s, int n, int l) {for(int i=n;i<s.length();i++) //начинаем удаление с n элемента if(i+l<s.length()) //проверка не выходит ли смещение за границы строки s[i]=s[i+l]; //если не выходит, просто переносим символ с позиции+l else s[i]='\0'; //иначе вводим на позицию пустой символ }
Сначала они будут заполнены значением, большим своего индекса на 1, а потом каждому элементу, начиная со второго (который А[1]) будет присвоено значение предыдущего элемента и 1 распространится везде.
Для проверки была написана программа с отладочной выдачей.
var
a:array[0..10] of integer;
i:integer;
begin
for i:=0 to 10 do begin a[i]:=i+1; Write(a[i],' ') end;
Writeln;
Write(a[0],' ');
for i:=1 to 10 do begin a[i]:=a[i-1]; Write(a[i],' ') end
end.
Результаты
1 2 3 4 5 6 7 8 9 10 11
1 1 1 1 1 1 1 1 1 1 1
ответ: 3)
#include <iostream>
#include <string>
using namespace std;
void DeleteStr(string&, int, int);
int main(void)
{string s;
int n,l;
cin>>s>>n>>l;
DeleteStr(s,n,l);
cout<<s<<endl;
return 0;}
void DeleteStr(string &s, int n, int l)
{for(int i=n;i<s.length();i++) //начинаем удаление с n элемента
if(i+l<s.length()) //проверка не выходит ли смещение за границы строки
s[i]=s[i+l]; //если не выходит, просто переносим символ с позиции+l
else
s[i]='\0'; //иначе вводим на позицию пустой символ
}
Пример ввода:
Caster 1 4
Пример вывода:
Cr