我有一个文本文件,其中出现两种类型的格式。扫描完第一种格式类型并将其放入数组后,遇到第二种格式:
$$$$$$$
我有一棵装满钱的大树
如何忽略 $$$$$$$ 行并将句子扫描到一个新数组中,其中每个元素都是句子中的一个单词:
`char sentence[MAX_SENTENCE_LENGTH]`
我尝试过使用:
for (i = 0; i < MAX_SENTENCE_LENGTH; i++){
if (scanf(" $$$$$$$ %s", sentence[i]) !=1){
break;
但这并没有考虑到 $$$$$$$
在句子之前只出现一次的事实。它还返回格式警告:
格式指定类型“char *”,但参数类型为“int”[-Wformat]
最佳答案
程序中的主要问题是您希望读取字符串数组,但您的数据结构是单个字符串。你的编译器实际上应该警告你。
然后,扫描 "$$$$$$$ %s"
格式的第一个元素,以下仅使用 "%s"
格式:
const int MAX_SENTENCE_LENGTH = 30;
const int MAX_NR_OF_SENTENCES = 30;
char sentence[MAX_NR_OF_SENTENCES][MAX_SENTENCE_LENGTH];
int i=0;
if (scanf(" $$$$$$$ %29s", sentence[i]) == 1) {
i++;
while (i < MAX_NR_OF_SENTENCES) {
if (scanf("%29s", sentence[i]) !=1){
break;
}
i++;
}
}
关于c - 如何将句子扫描到字符串数组中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43972617/