[노트] C 언어 면접문제: 문자열이 자모를 다시 배열해서 대칭이 될 수 있는지 판단
2041 단어 C 언어
출처: 모 500대 기업 면접 문제
사고방식: 문자열을 스캔하여 각 문자의 출현 횟수를 누적하고 홀수인 문자의 수가 1개를 초과하지 않으면 True를 되돌려주고 그렇지 않으면 False를 되돌려줍니다
#include "stdio.h"
#include "stdlib.h"
#include "string.h"
//----------------------------------------
// ,
// "abab", "abba", True
// "abc", False
//----------------------------------------
bool CheckIfCanBeSymmetric(char *str) {
// , , 1 , True, False
int i = 0;
int n = 0;
int CountList[256] = {0}; // ASCII
if (str == NULL) return false;
if (strlen(str) <= 1) return true;
// , ++
for (i = 0; i < strlen(str); i++)
CountList[str[i]]++;
// , 1 , False
for (i = 0, n = 0; i < 255; i++) {
if (CountList[i] % 2 == 1) n++;
if (n > 1) return false;
}
return true;
}
//-------------------------------------------------------------------------
void TestCheckIfCanBeSymmetric(void) {
int n;
char s1[] = "ab--++++ca@@bc!!!!~~";
char s2[] = "abcbc";
char s3[] = "abbc";
char s4[] = "";
printf("%s is %d
", s1, CheckIfCanBeSymmetric(s1));
printf("%s is %d
", s2, CheckIfCanBeSymmetric(s2));
printf("%s is %d
", s3, CheckIfCanBeSymmetric(s3));
printf("%s is %d
", s4, CheckIfCanBeSymmetric(s4));
}
//-------------------------------------------------------------------------
int main(int argc, char *argv[]) {
TestCheckIfCanBeSymmetric();
getchar();
return 0;
}
Technorati 태그:
C 언어 ,
면접 문제
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
C 언어 체인 시계는 뱀을 탐식하는 작은 게임을 실현한다본고의 실례는 여러분에게 C 언어 체인표가 뱀 탐식 게임을 실현하는 구체적인 코드를 공유하여 참고하도록 하였으며, 구체적인 내용은 다음과 같다. 프로젝트 이름: 뱀놀이 운영 환경: Linux 프로그래밍 언어: C 언...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.