수다닷컴

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

문자열 비교 함수 만들기

유희

2023.04.01

총 3개의 문자열을 입력받아서 문자열의 순위가 높은 순서대로 문자열을 결합하는 프로그램을 작성해 보자. 문자열의 순위 결정은 사전 편찬 순서를 기반으로 한다. 사전 편찬순서의 뒷부분으로 갈수록 우선순위가 높은 것으로 한다.
예를 들어 다음과 같이 3개의 문장을 입력받았다면,
aaaaa, bbbbb, ccccc

다음과 같은 문장을 만들어서 출력해 준다.
cccccbbbbbaaaaa

참고로, 이문제는 그리 간단한 문제가 아니다. 3개의 문자열을 가지고 만들어 볼수 있는 경우의 수만 해도 6가지이기때문이다.(예:str1이 가장크고, str2가 가장 작은 경우) 연습장을 갖다 놓고, 모든 경우의수를 먼저 계산해본다음 프로그램을 구현해야 한다.기본적으로 문자열 3개의 순위 결정을 위해서는 총 3번의 비교를 하는 수 밖에 없다. 따라서 어떠한 경우의 수가 나오건, if문이 3번 중첩될수밖에 없는 것이다. 위의 방식 이오이에도 다양한 형태의 구성이 나올수는 있지만, 크게 달라지지는 않을 것이다. 기본 틀은 같다.

참고로 함수의 기능을 조금 더 세분화하면 프로그램의 가독성은 높아지게 된다. 예를 들어서 2개의 문자열 중 큰 문자열을 반환하는 함수 하나와 3개의 문자열중 가장 큰 문자열을 반환하는 함수 하나를 각각 구현한다. 그리고 이 함수들을 이용해서 위에서 제시한 함수 concat3의 기능을 구현하는 것이다.

이렇게 나와있는데요.
2개의 문자열 중 큰 문자열을 반환하는 함수 하나와 3개의 문자열중 가장 큰 문자열을 반환하는 함수 하나를 각각 구현하고. 그리고 이 함수들을 이용해서 위에서 제시한 함수 concat3의 기능을 구현하려면 어떻게해야되죠?

도무지 생각이 안나서 답을 봤는데

#include stdio.h
#include string.h

void concat3(char *str1, char *str2, char *str3, char *constr);

int main(void)
{
char str1[50];
char str2[50];
char str3[50];
char constr[150];

printf(3개의 문자열 입력: );
scanf(%s %s %s, str1, str2, str3);
concat3(str1, str2, str3, constr);
puts(constr);

return 0;
}

void concat3(char *str1, char *str2, char *str3, char *constr)
{
if(strcmp(str1, str2)==1)
{
if(strcmp(str1, str3)==1) // str1이 제일 크다면
{
strcpy(constr, str1);
if(strcmp(str2, str3)==1) // str1, str2, str3
{
strcat(constr, str2);
strcat(constr, str3);
}
else // str1, str3, str2
{
strcat(constr, str3);
strcat(constr, str2);
}
}
else // str3가 제일 크다면
{
strcpy(constr, str3);
if(strcmp(str1, str2)==1) //str3, str1, str2
{
strcat(constr, str1);
strcat(constr, str2);
}
else // str3, str2, str1
{
strcat(constr, str2);
strcat(constr, str1);
}
}
}
else
{
if(strcmp(str2, str3)==1) //str2가 제일 크다면
{
strcpy(constr, str2);
if(strcmp(str1, str3)==1) //str2, str1, str3
{
strcat(constr, str1);
strcat(constr, str3);
}
else // str2, str3, str1
{
strcat(constr, str3);
strcat(constr, str1);
}
}
else // str3가 제일 크다면
{
strcpy(constr, str3);
if(strcmp(str1, str2)==1) // str3, str1, str2
{
strcat(constr, str1);
strcat(constr, str2);
}
else // str3, str2, str1
{
strcat(constr, str2);
strcat(constr, str1);
}
}
}
}

답지에는 따로 구현이 안되있네요.
제가 원하는 것은2개의 문자열 중 큰 문자열을 반환하는 함수 하나와 3개의 문자열중 가장 큰 문자열을 반환하는 함수 하나를 각각 구현하고. 그리고 이 함수들을 이용해서 위에서 제시한 함수 concat3의 기능을 구현하는 것인데...
전체 로직 한번만 짜주세요.ㅠ.ㅠ;
남이 풀어봐야 소용없다는걸 잘 알지만...이 문제만이라도 손을 빌리고 싶습니다.
c언어 고수분들 도와주세요 ㅠ.ㅠ;

신청하기





COMMENT

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

  • 아이돌

    이렇게 해도 될거 같네요..
    #include stdio.h
    #include string.h

    void main()
    {
    \tchar str1[50];
    \tchar str2[50];
    \tchar str3[50];
    \tchar* str[3];
    \tchar* old;
    \tprintf(\first : \);
    \tgets(str1);
    \tfflush(stdin);
    \tprintf(\second : \);
    \tgets(str2);
    \tfflush(stdin);
    \t

번호 제 목 글쓴이 날짜
2704365 c언어 문제안되서물어봅니다 (3) 맑은가람 2025-08-09
2704338 다항식의 뺄셈에 대해 질문드립니다... (1) 여자 2025-08-09
2704311 센서를 이용한 라인 주행인데 명령어좀 알려주세요 ㅠ_ㅠ (3) 초록이 2025-08-09
2704284 배열for문;; (3) 은솜 2025-08-08
2704255 readline(int fd, char *buf, int nbytes)함수를 구현하는법좀..ㅠㅠ 파라나 2025-08-08
2704196 간단한 c언어좀 만들어주세요 (2) 슬S2아 2025-08-08
2704118 성적에서 등수 구하기 (4) 딥레드 2025-08-07
2704062 알고리즘 알려주세요 나리 2025-08-06
2704035 답은 나오는데 과정에서 `` 약간 이상합니다.ㅎㅎ 답만나와버려요 핫블랙 2025-08-06
2703979 문자열 EEPROM 작성 방법 문의드립니다. 그녀는귀여웠다 2025-08-06
2703954 키보드를 입력하면 캐릭터를 움직이기 질문 (7) 좋아해 2025-08-05
2703924 계속 에러가... (4) 눈꽃 2025-08-05
2703897 배열의 최댓값과 최솟값 차이 구하기 (1) 하늬 2025-08-05
2703869 C언어 질문입니다 급해용!!! ㅠㅠ (2) 덕이 2025-08-05
2703814 C로 프로그램을 만들때 도스창 말고 다르게 만드는방법이 있을까요? (2) 소심한여자 2025-08-04
2703785 fread로 읽은 bin파일을 구조체로 저장할때 관해서 질문드립니다. (1) 감추어왔던 2025-08-04
2703758 오름차순으로 정렬하는 프로그램인데 잘 안되요.. (2) 해긴 2025-08-04
2703730 Deep copy 질문드립니다 (3) 원술 2025-08-03
2703700 평균 시간복잡도 구하는 방법을 잘모르겟어요 sin 2025-08-03
2703668 딱 한부분만 설명좀 부탁드립니다 진짜 간단한거에요 ㅠ (2) 이름이없다고 2025-08-03
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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