gpt4 book ai didi

C字符串与字符的输入、比较

转载 作者:行者123 更新时间:2023-11-30 17:44:29 27 4
gpt4 key购买 nike

我正在学习 C 编程,为了练习,我找到了一个需要解决的任务。这有点像一个游戏,有人选择一个单词,其他人猜测字母。我必须检查有多少给定的单词可能是所选单词的正确答案。

输入:

3 3//数字 n 和 m n-要比较的单词数,m-检查的字母数

A C D//m 个字母,用空格分隔

--CA//给出猜测的单词

KUCA//要检查的 n 个单词在本例中是否匹配“--CA”

ZGRADA//单词之间用 Enter(\n) 分隔

MACA//在这种情况下,“MACA”与“--CA”不匹配,因为猜测的字母中有一个“A”,但在代表某些字母的第二个破折号上没有“A”

输出:1

想法是检查长度是否相同,如果相同,则应检查当前字符是否为“-”,如果是,则应检查 m 个字符中的每一个(猜测的字母)是否与当前字符匹配,如果是,则 -; (sol--;)(在声明 rez=n; 之前)

这是我的代码:

#include <stdio.h>
#include <stdlib.h>

int main()
{
int n=0,i=0,m=0,j=0,k=0,duzina=0,rez=0,br=0;
char slova[26], rec[30], pot[30],c;

scanf("%d %d\n",&n,&m);

br = 0;
while ( (c = getchar()) != '\n' ){
if ( c != ' ' ) { slova[br] = c; br++; }
}
slova[br] = '\0';
br = 0;
while ( (c = getchar()) != '\n' ){
rec[br] = c;
br++;
}
rec[br] = '\0';
rez=n;
duzina=strlen(rec);
for(i=0;i<n;i++){
br=0;
while ( (c = getchar()) != '\n' ){
pot[br] = c;
br++;
}
pot[br] = '\0';
if(duzina!=strlen(pot))
rez--;
else{
for(j=0;j<duzina;j++){
if(rec[j]=='-'){
for(k=0;k<m;k++){
if(pot[j]==slova[k]){
rez--;
break;
}
}
}
else{
if(rec[j]!=pot[j])
rez--;
}
}
}
}
printf("%d",rez);

return 0;
}

所以我的问题在于错误的答案,我不知道为什么。

代码适用于上面的示例,但对于这个它显示 -8,它应该是 3:

10 5

A I L B X

--A--AB-X

PUAQFABHX

IIAFWABIX

MHAKVABPX

BQAXWABWX

TEAUIAB

PCALIABLX

雷哈克杰

NWNKSGBNP

ZOCZKJWZR

ROAJRABZX

最佳答案

在以下代码的 else 部分:

if(duzina!=strlen(pot))
rez--;
else{
for(j=0;j<duzina;j++){
if(rec[j]=='-'){
for(k=0;k<m;k++){
if(pot[j]==slova[k]){
rez--;
break; // <-- This will break out of the 'for-k' loop
}
}
}
else{
if(rec[j]!=pot[j])
rez--; // <-- Are you missing a 'break' here?
}
}
}

rez递减后,需要跳出外循环。

关于C字符串与字符的输入、比较,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19983424/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com