问题描述
我正在 HackerRank 中进行 30 天代码中的第 8 天,但我遇到了 strcmp
问题。
代码询问用户姓名和号码,然后询问其他姓名,如果之前没有输入姓名,则输出Not found
,如果输入,则输出姓名和号码。但出于某种原因,输出仅适用于 for
语句的最后一个循环。
代码:
#include <stdio.h>
#include <string.h>
#include <math.h>
#include <stdlib.h>
typedef struct {
char name[100];
int number;
} phonebook;
int main() {
int n = 0;
do {
scanf("%i",&n);
} while (n < 1 || n > 100000);
int i = 0;
phonebook people[n];
for (i = 0; i < n; i++) {
scanf("%s %i",people[i].name,&people[i].number);
}
char othernames[n][100];
for (i = 0; i < n; i++) {
scanf("%s",othernames[i]);
}
for (i = 0; i < n; i++) {
if (strcmp(othernames[i],people[i].name) == 0) {
printf("%s=%i\n",people[i].number);
} else {
printf("Not found\n");
}
}
return 0;
}
解决方法
你没有找到从头到尾的othernames
每次都比较people
,所以需要替换
for (i = 0; i < n; i++) {
if (strcmp(othernames[i],people[i].name) == 0) {
printf("%s=%i\n",people[i].name,people[i].number);
}
else {
printf("Not found\n");
}
}
到
bool found = false;
for (i = 0; i < n; i++) {
for ( j = 0 ; j < n ; j++ ) {
if (strcmp(othernames[j],people[i].name) == 0) {
printf("%s=%i\n",people[i].number);
found = true;
}
}
}
if ( found == false ) printf("Not found\n");
,
问题是 othernames
应该只是一个 char
数组,而不是一个矩阵。对于输入的每个其他姓名,您必须扫描整个电话簿才能找到它或显示 Not found
。按照编码,您只测试键入的第 i 个其他名称是否恰好对应于电话簿中的第 i 个条目。
这是修改后的版本:
#include <stdio.h>
#include <string.h>
typedef struct {
char name[100];
int number;
} phonebook;
int main() {
int n = 0;
do {
if (scanf("%i",&n) != 1)
return 1;
} while (n < 1 || n > 100000);
phonebook people[n];
for (int i = 0; i < n; i++) {
if (scanf("%99s %i",&people[i].number) != 2)
return 1;
}
for (int i = 0; i < n; i++) {
char othername[100];
if (scanf("%99s",othername) != 1)
break;
int j;
for (j = 0; j < n; j++) {
if (strcmp(othername,people[j].name) == 0) {
printf("%s=%i\n",people[i].number);
break;
}
}
if (j == n) {
printf("Not found\n");
}
}
return 0;
}
请注意,将电话号码存储为 int
值可能不是一个好主意。最好使用 char
数组,因此初始 0
很重要并且可以存储更长的数字。