inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C++

6.6 C언어 스타일의 배열 문자열

[15:39] strcmp, strcat을 스스로 구현해보기

해결된 질문

413

호두

작성한 질문수 85

0

안녕하세요?

교수님 정말 그 동안 노력 안 했던 거 탓하면서 처절하게 풀었어요 .

그래도 열심히 하면 조금이라도 좋아지겠지 하면서요!

그냥 결과 끼워맞추기인데요.

<strcmp>

1. 길이가 다르면 다른 문자열이니까 -1을 리턴해라

2. 길이가 같다면 그 길이 만큼 돌면서 각 배열의 같은 위치의 문자를 하나씩 비교해서 다른 게 있으면 -1을 리턴하고 다른 게 없으면 0을 리턴한다.

머리가 복잡해서 myStrlen 함수를 먼저 만들어서 길이 비교를 했고요.

그걸 이용해서 myStrcmp를 만들었어요.

<결과화면>

<코드>

// strcmp_self.cpp : This file contains the 'main' function. Program execution begins and ends there.
//

#include <iostream>
using namespace std;

void Compare(int input);
int myStrcmp(const char arr[],const char arr2[]);
int myStrlen(const char arr[]);
int main()
{
    char name1[] = "ABCDEF";
    char name2[] = "ABCDEF";
    char name3[] = "AbCDEF";

    cout << name1 << " == " << name2 << " ? " << endl;

    Compare(myStrcmp(name1, name2));
    

    cout << name1 << " == " << name3 << " ? " << endl;

    
    Compare(myStrcmp(name1, name3));

    
    

    //cout << "strcmp(name1, name2) : " << strcmp(name1, name2) << endl;



    return 0;
}
int myStrlen(const char arr[])
{
    int count = 0;
    while (1)
    {
        if (arr[count] == '\0')
            break;
        count++;
    }
    return count;
}
int myStrcmp(const char arr[], const char arr2[])
{
    int result = 0;
    if (myStrlen(arr) != myStrlen(arr2))
    {
        result = -1;
    }
    else
    {
        for (int i = 0; i < myStrlen(arr); ++i)
        {
            if (arr[i] != arr2[i])
                result = -1;
            else
                result += 0;
        }
    }
    return result;
}
void Compare(int input)
{
    if (input == 0)
    {
        cout << "Equal" << endl;
    }
    else
    {
        cout << "Not Equal" << endl;
    }
}

<strcat>

<결과화면>

<코드>

// concatenate_test.cpp : This file contains the 'main' function. Program execution begins and ends there.
//
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>

using namespace std;

int myStrlen(const char arr[]);
char* myStrcat(const char* xconst char* y);
int main()
{
    char str1[] = "Jack";
    char str2[] = " Jack";

    //strcat(str1, str2);

    cout << myStrcat(str1, str2) << endl;


    //cout << str1 << endl;

    return 0;
}
char* myStrcat(const char* xconst char* y)
{
    //cout << myStrlen(x) + myStrlen(y) + 1 << endl;
    int length = myStrlen(x) + myStrlen(y) + 1;

    //char concatenatedString[20]{ '\0',};

    char* concatenatedString = new char[length] {'\0',};


    //concatenatedString[0] = 'H';
    //concatenatedString[1] = 'I';

    for (int i = 0; i < myStrlen(x); ++i)
    {
        concatenatedString[i] = x[i];
    }

    for (int j = 0; j < length; ++j)
    {
        concatenatedString[myStrlen(x) + j] = y[j];
    }

    //delete[] concatenatedString;

    /*concatenatedString[5] = y[1];
    concatenatedString[6] = y[2];*/

    
    return concatenatedString;
}

int myStrlen(const char arr[])
{
    int count = 0;
    while (1)
    {
        if (arr[count] == '\0')
            break;
        count++;
    }
    return count;
}

감사합니다.

C++

답변 1

1

홍정모

일단 초보때는 기능이 정확하게 작동하면 충분합니다.

변수가 메모리에 저장되는 것을 알려주는 강의가 어떤강의였죠

1

461

1

메모리 주소 10진수로 출력

1

650

1

클래스 템플릿 특수화에서 boolalpha로 표현된 리턴값에 대해 질문이 있습니다.

1

496

1

여러가지 리턴 타입에 관한 강의가 어떤 걸까요?

1

529

1

메모리 주소에 관한 질분

0

676

1

인터페이스 클래스에서 reportError의 매개변수에 대해 궁금한 것이 있습니다.

0

547

1

형변환 오버로딩에서 const 관련 질문이 있습니다.

0

439

1

Digit 뒤에 reference를 사용하는 이유

0

504

1

4.2 전역 변수, 정적 변수, 내부 연결, 외부 연결

0

319

1

dat파일이...

0

535

1

TODO:대입 연산자 오버로딩에 대한 소스코드입니다.

0

640

1

복사 생성자 관련 질문이 있습니다.

0

450

1

수업 중 궁금한점이 있습니다.

1

386

1

라이브러리자체가 이해가 되지 않습니다.

0

558

1

마지막 예제 질문

0

299

1

증감연산자 위치에 따른 수행 순서 질문입니다.

0

371

1

단항 연산자 오버로딩에서 return 부분에 질문이 있습니다.

1

408

1

friend함수 관련 질문이 있습니다.

0

308

1

operator+ 정의부분에서 궁금한 것이 있습니다.

0

444

1

3분 17초 질문

0

347

1

함수에 값을 대입한다는 개념이 이해가 되지 않습니다.

0

443

1

int getvalue() const에서 const는 왜 뒤에 붙는건가요?

0

440

2

const Something &st에서 const를 빼면 안되나요?

0

296

1

friend함수는 다른 클래스의 멤버함수로 쓸 수 없나요??

1

489

1