문자열과 문자열 비교하는 부분을 질문 드립니다.
은송이
질문 제목 : 문자열과 문자열 비교중 일부만 같으면 전체를 반환 할 수있는지....제가 원카드 게임을 만들고 있는데 카드 비교 부분이 막히네요질문 내용 :
요약에서 말씀 드린대로 지금 제가 원카드 게임을 만들고 있느데요
카드를 나누어서 한장의 카드와 플레이어가 가지고 있는 카드와 비교를해서
한장을 내야하는데 조건이 문자와 숫자중 하나만 같으면 낼수 있는거라서요
비교 자체는 둘중 하나만 같으면 되는 것인데
strpbrk함수를 사용하니 다른 문자 예를 들어서 ◆9와 ♥10이라면 낼수가 없는데 문자가 같다고 인식되버리네요
모든 문자가 그런것은 아닌 것 같은데 주소 자체에서 같은 부분이 인식 되어버린 다면 곤란하긴한데
이문제 때문에 낼 수 없는 카드까지 내게 되버려서 고민이네요
아래는 제가 지금 까지 만든 소스구요
카드 분배 삭제 (카드를 선택해서 버리는 것 )까지 구현 했어요//원카드 게임 메인 함수
#include stdio.h
#include stdlib.h
#include string.h
#include time.h
#define card_max 14
typedef struct _card{
char *player_1[10]; //첫번째 사용자의 카드
char *player_2[10]; //두번째 사용자으 카드
char *somecard; // 비교 할 기준이 되는 카드
}i_card;
static int u_card_max = 7; //사용자가 나누어 가질 카드 수 6장
void shuffle(i_card *card, char *card[], int num[])
{
int i,j,k,temp;
srand(time(null));
for(i=1,k=1; icard_max; i++)
{
do
{
//중복 숫자 검사
temp = rand()%54;
for(j=1; ji; j++)
if(temp == num[j] )
break;
}while(ji);
num[i] = temp;
//카드 초기화
if(iu_card_max){
card-player_1[i] = (char*)malloc( sizeof(char) );
strcpy(card-player_1[i], card[num[i]]); //플레이어 1 초기화
}
else if(iu_card_max-1 && icard_max-1)
{
card-player_2[k] = (char*)malloc( sizeof(char) );
strcpy(card-player_2[k], card[num[i]]); // 플레이어2 초기화
k++;
}
else{
card-somecard = (char*)malloc( sizeof(char) );
strcpy(card-somecard, card[num[i]]); // 비교카드 초기화
}
}
}
void print(i_card *card, char *card[])
{
int i;
//초기화된 카드 출력
printf(컴퓨터 );
for(i=1; iu_card_max; i++){
printf(%d:%4s ,i, card-player_1[i]);
}
printf(\n비교카드 %s , card-somecard);
printf(\n사용자 2번 );
for(i=1; iu_card_max; i++){
printf(%d:%4s ,i, card-player_2[i]);
}
}
void choice(i_card *card)
{
int num,i,j;
char *temp;
while(1){
printf(카드를 선택 하세요 (0입력시 한장 추가) );
scanf(%d, &num);
printf(%s \n,card-player_2[num] );
if( strpbrk(card-somecard, card-player_2[num]) != null)
{
card-somecard = card-player_2[num];
for(i=num; iu_card_max-1; i++)
{
card-player_2[i] = card-player_2[i+1];
}
u_card_max--;
}
else printf(버릴 수 있는 카드가 아닙니다.\n);
for(i=1; iu_card_max; i++)
printf(%d:%4s , i, card-player_2[i]);
printf(\n비교카드 %s \n, card-somecard);
}
}
}
void main()
{
char *card[54] =
{♡a,♡2,♡3,♡4,♡5,♡6,♡7,♡8,♡9,♡10,♡j,♡q,♡k, // 0~12 하트
◇a,◇2,◇3,◇4,◇5,◇6,◇7,◇8,◇9,◇10,◇j,◇q,◇k, // 13~25 다이아몬드
♣a,♣2,♣3,♣4,♣5,♣6,♣7,♣8,♣9,♣10,♣j,♣q,♣k, // 26~38 클로버
♠a,♠2,♠3,♠4,♠5,♠6,♠7,♠8,♠9,♠10,♠j,♠q,♠k, // 39~51 스페이드
⊙j,◎j //52 칼라조커, 53 블랙조커
};
int num[card_max];
i_card card;
shuffle(&card,card,num);
print(&card, card);
printf(\n);
choice(&card);
}
-
BabySue
CARD는 출력 용도로만 쓰고 0~53을 담고 있는 숫자배열로 처리하는게 간단할텐데요..
-
움찬
유니코드로 쓰셔야 할 것 같은데요..
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676182 | 숫자 순서대로 배열하는법 | 권뉴 | 2024-11-24 |
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |