Есть строка типа string
"1231.1232!1233.1234.1235!1236."
надо получить строку
"1231.1233.1234.1236."
Никак не могу додуматься, как разбить на отдельные предложения или же сразу удалять..может кто-нибудь наводку кинет?..
int main() {Пойдет?
char s[256] = "1231.1232!1233.1234.1235!1236.";
char result[256] = {0}, *res;
res = result;
int count = 0;
for(char *p = s; *p; p++) {
switch(*p) {
case '.':
case '?':
*res++ = *p;
count = 0;
break;
case '!':
res -= count;
break;
default:
*res++ = *p; count += 1;
}
}
*res = '\0';
puts(result);
return 0;
}
#include <stdio.h>
#include <string.h>
#include <iostream.h>
using namespace std;
int main() {
string s1="1231.1232!1233.1234.1235!1236.";
char * s = new char[s1.size()+1];
strcpy(s, (char *)s1.c_str());
char result[s1.size()] ;//= {0};
char *res;
res = result;
int count = 0;
for(char *p = s; *p; p++) {
switch(*p) {
case '.':
case '?':
*res++ = *p;
count = 0;
break;
case '!':
res -= count;
break;
default:
*res++ = *p; count += 1;
}
}
*res = '\0';
puts(result);
s1=result;
return 0;
}
#include <string>Попроще будет...
#include <iostream>
using namespace std;
int main() {
string s = "1230!1231.1232!1233.1234.1235!1236.1237!";
cout << s << endl;
size_t found = s.find('!');
while(found != string::npos) {
size_t prev = s.find_last_of(".?", found);
if(prev == string::npos) prev = (size_t)(-1);
s.erase(prev + 1, found - prev);
found = s.find('!');
}
cout << s << endl;
return 0;
}