- 001
- 002
- 003
- 004
- 005
- 006
- 007
- 008
- 009
- 010
- 011
- 012
- 013
- 014
- 015
- 016
- 017
- 018
- 019
- 020
- 021
- 022
- 023
- 024
- 025
- 026
- 027
- 028
- 029
- 030
- 031
- 032
- 033
- 034
- 035
- 036
- 037
- 038
- 039
- 040
- 041
- 042
- 043
- 044
- 045
- 046
- 047
- 048
- 049
- 050
- 051
- 052
- 053
- 054
- 055
- 056
- 057
- 058
- 059
- 060
- 061
- 062
- 063
- 064
- 065
- 066
- 067
- 068
- 069
- 070
- 071
- 072
- 073
- 074
- 075
- 076
- 077
- 078
- 079
- 080
- 081
- 082
- 083
- 084
- 085
- 086
- 087
- 088
- 089
- 090
- 091
- 092
- 093
- 094
- 095
- 096
- 097
- 098
- 099
- 100
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>
char** del_arr(char **arr,int *size_i,int count,char *slovo,int len);
char** Delete(char **arr,int i,int *size_i);
void poisk(int size_j,char *arr,char *slovo,int len,int *c);
char* s_enter();
void arr_enter(int size_i ,char ***arr);
void arr_out(int size_i, char ***arr);
//void str_cpy(char **arr,char **res_arr,int size_src);
int main(void)
{
clrscr();
int size_i, size_j, count, len;
char **arr, *razd, *slovo;
printf("Vvedite kolichestvo strok > 1\n");
scanf("%d",&size_i);
if(size_i<=1)
size_i=2;
printf("Vvedite stroki texta\n");
getchar();
arr_enter(size_i, &arr);
printf("Vvedite stroku razdeliteley\n");
razd=s_enter();
puts(razd);
printf("Vvedite kontrol'noe slovo\n");
slovo=s_enter();
len=strlen(slovo);
puts(slovo);
printf("Vvedite kolichestvo kontrolnih slov\n");
scanf("%d",&count);
printf("Vvedennie stroki:\n");
arr_out(size_i,&arr);
arr=del_arr(arr,&size_i,count,slovo,len);
arr_out(size_i,&arr);
getch();
return 0;
}
char** del_arr(char **arr,int *size_i,int count,char *slovo,int len)
{
int i=0, c=0,size_j,p;
for(;i<*size_i;)
{
size_j=strlen(arr[i]);
poisk(size_j,arr[i],slovo,len,&c);
if(c==count)
{
p=1;
Delete(arr,i,size_i);
free(arr[*size_i]);
*size_i--;
}
else
p=0;
if(p==0)
i++;
}
return arr;
}
char** Delete(char **arr,int i,int *size_i)
{
int size;
for(;i<((*size_i)-1);i++)
{
//size=strlen((*arr)[i+1]);
strcpy(arr[i],arr[i+1]);
puts(arr[i]);
//memmove((*arr)[i],(*arr)[i+1],size+1));
}
return arr;
}
void poisk(int size_j,char *arr,char *slovo,int len,int *c)
{
int j=0, r=1;
for(;j<size_j;)
{
if(arr[j]==slovo[0])
{
while(r<=len)
{
j++;
if(arr[j]==slovo[r])
r++;
else
break;
}
*c++;
r=1;
}
else
j++;
}
//return c;