[MFC]영문자열 분류 및 정렬 질문입니다.
루나
질문 제목 :
영문자열 분류 및 정렬 질문입니다.
cstringarray로 선언된m_arrsort배열에 있는 영문자를 종류별로 나누고 카운트하고
cstringarray로 선언된 sort배열에 있는 문자열을 대소문자 구분없이 비교하여 알파벳순으로 정렬하는
프로그램을 짜려고합니다.
질문 내용 :
int i = 0;
int k = 0;
cstringarray sort;
// m_arrsort배열에 있는 영문자를 종류별로 나누고 카운트하는 부분
//모든 영문자열을 한번씩만 저장
for(i=0; im_arrsort.getsize(); i++)
{
int cnt = 0;
bool flag = true;
cstring temp;
if(i == 0)
{
flag = true;
}
else
{
for(k=0; ki; k++)
{
if(m_arrsort[i] == m_arrsort[k])
{
flag = false;
break;
}
}
}
if(flag == true)
{
for(k=i; km_arrsort.getsize(); k++)
{
if(m_arrsort[i] == m_arrsort[k])
{
cnt++;
}
}
temp.format(%s(%d), m_arrsort[i], cnt);
sort.add(temp);
}
}
// sort배열에 있는 문자열을 대소문자 구분없이 비교하여 알파벳순으로 정렬하는 부분
for(i=0; isort.getsize(); i++)
{
for(k=i+1; ksort.getsize(); k++)
{
cstring a;
cstring b;
a = sort[i];
b = sort[k];
a.makelower();
b.makelower();
if(compare(a,b) == 1)
{
cstring temp;
temp = sort[i];
sort[i] = sort[k];
sort[k] = temp;
}
}
}
m_ewsort.empty();
for(i=0; isort.getsize(); i++)
{
if(i (sort.getsize()-1))
{
m_ewsort += (sort[i] + \r\n);
}
else if(i == (sort.getsize()-1))
{
m_ewsort += sort[i];
}
}
setdlgitemtext(idc_wsort, m_ewsort);
이렇게 짜봤는대 속도가 너무 느리더군요;;
파일크기 3~4메가정도 되는 텍스트파일로 이것을 돌려보면 20초가 좀안되게 걸리는 듯 합니다
(물론 중복많어가 많으면 짧게걸리고 적으면 오래걸립니다.)
이걸 속도를 좀 빠르게 대체할만한 방법이 궁금해서 질문합니다 ㅠ
ps.
idc_wsort - dialog editbox의 이름
m_ewsort - cstring으로 된 멤버변수
m_arrsort에는 [0]~[m_arrsort.getsize()-1]까지 알파벳 문자열이 들어있습니다.
compare()함수의 내용은 다음과 같습니다.
while(*a && (*a==*b))// a안에 값이 존재하고 a와b의 값이 같을때
{
a++;
b++;
}
return (*a*b) - (*a*b);
-
민트향
네 알겠습니다^^ 감사해요^^
-
꼬붕
아... 공지 대충읽어서 올리지말란걸로봤네요 ㅠㅠ
수정할께요 ㅠ -
Aileen
공지사항을 읽어보세요.. 왜 답글이 안달리는지
구문의 문제라면 소스 한줄만 올려도 어디가 잘못됐다 라고 지적해 줄 수 있는거고..
내가 이방법을 아는데 이거보다 나은 방법이 없는지 묻는것도 마찬가진데..
질문하신건 소스 몇줄로 될 일이 아닌거 같네요..
게시판 첫머리에 질문올리기전에 vc++은 프로젝트를 올리라고 빨간 공지로 되어있어요
질문하신 내용은 프로젝트를 전체로 올려도 될까 말까 한거 같네요.. -
봄나비
흠... 파일을 보내드려볼까요?
-
소심한여자
저코드만으로는.. 저는 모르겠네요
프로젝트와 샘플파일이 있으면 해결할수 없더라도 보기라도 할텐데 하는 아쉬움이 남네요 -
맑은
처음 for문에서 시간이 오래걸려요 ㅠ
-
사랑은아픔
정확히 어느부분에서 시간을 잡아먹는지 찾아야겠네요
의심되는 부분이 어딘지 알아야 그걸 대체하는 성능좋은 STL 이라도 추천하겠죠..
파일에서 읽는거라면 그부분도 의심대상이 됩니다
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2695626 | 피보나치수열 과제 때문에 질문 드립니다. (6) | 옆집언니 | 2025-05-22 |
2695595 | 포인트공부중입니다 int형에서 4=1 인가요? (3) | 족장 | 2025-05-22 |
2695567 | 드라이브 고유번호를 가져오는 함수 (2) | 초코맛사탕 | 2025-05-21 |
2695533 | 음수의 산술변환! 질문이요 ㅠㅠ... (4) | 꽃여름 | 2025-05-21 |
2695506 | 구조체 배열 이용 도서목록 출력 프로그램 (1) | 가을귀 | 2025-05-21 |
2695450 | c언어 함수 질문이요.... | 이슬비 | 2025-05-20 |
2695403 | VirtualAlloc함수 및 메모리 질문 | 크리에이터 | 2025-05-20 |
2695355 | c언어 for함수 | 미쿡 | 2025-05-19 |
2695327 | 안녕하세요 제가 이번에 좀 큰 프로그램을.. | 악당 | 2025-05-19 |
2695295 | mutex동기화의 thread기반 채팅 서버소스 질문입니다 | 그루터기 | 2025-05-19 |
2695270 | 질문이요..swap 관한겁니다..ㅠㅠ (3) | 콩알녀 | 2025-05-19 |
2695244 | 노땅초보궁금한게 하나 있는데요..반복문(while문)초보자질문 (6) | 큰꽃늘 | 2025-05-18 |
2695166 | do while 문 어떤것이잘못된건지 모르겠어요 (2) | 아이폰 | 2025-05-18 |
2695122 | 구조체에 대해 물어보고 싶은게 있습니다 ^^^.. (7) | 수련 | 2025-05-17 |
2695091 | txt 파일 입출력 후 2차 배열에 저장하기입니다. (3) | 헛장사 | 2025-05-17 |
2695063 | 수도요금 프로그램좀 짜주세요. | 시내 | 2025-05-17 |
2695033 | 답변좀요ㅠㅠ (1) | 비사벌 | 2025-05-16 |
2695010 | C++의 STL은 왜 굳이 템플릿화 시켜서 라이브러리를 만드나요? (초보수준의 질문..) (2) | 엘보어 | 2025-05-16 |
2694958 | 로직이 변한다는 것에 대해서 궁금합니다. | 튼동 | 2025-05-16 |
2694929 | 열혈강의 25-2 두번째 문제 질문 | 지우개 | 2025-05-15 |