수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

[MFC]영문자열 분류 및 정렬 질문입니다.

루나

2023.04.01


질문 제목 :
영문자열 분류 및 정렬 질문입니다.
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);

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

  • 민트향

    네 알겠습니다^^ 감사해요^^

  • 꼬붕

    아... 공지 대충읽어서 올리지말란걸로봤네요 ㅠㅠ
    수정할께요 ㅠ

  • 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
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com