#include
#include
struct nodeString;
typedef struct nodeString *PNodeString;
struct nodeString {
char info;
PNodeString link;
};
PNodeString createNodeString() {
int i,m;
PNodeString t,q;
PNodeString node = (PNodeString)malloc(sizeof(struct nodeString));
q=node;
if (node == NULL) {
printf("分配串空间失败!");
free(node);
return 0;
}
else {
printf("分配串空间成功,其地址为:%x\n", node);
// node->info ='';
printf("请输入原串的长度:");
scanf("%d", &m);
for (i = 0; i < m-1; i++) {
t = (PNodeString)malloc(sizeof(struct nodeString));
node->link = t;
node = t;
}
node->link=NULL;
return q;
}
}
int isEmpty(PNodeString p) {
return p->info == '\0';
}
void insertChar(PNodeString p) {
PNodeString q=p;
printf("请逐个输入字符:");
while (q!=NULL) {
scanf("%c",&(q->info));
q= q->link;
}
printf("\n");
}
int main() {
PNodeString p;
p = createNodeString();
printf("原串是否为空:%d(1:是;0:否)\n", isEmpty(p));
insertChar(p);
}
前面的scanf("%d", &m);执行时,以回车来触发输入的结束,但是这个回车在这行输入时并没有被使用,所以留到了下一次输入。
解决方法:在%d后面加\n,或者%c之前加空格。
参考这里:https://blog.csdn.net/github_39363510/article/details/76419237
void insertChar(PNodeString p)
{
PNodeString q = p;
printf("请逐个输入字符:");
while (q != NULL)
{
scanf(" %c", &(q->info)); // 关键在这里,%c 的前面加上一个空格。
q = q->link;
}
}
要修改的地方是scanf(" %c", &(q->info));
,"%c"
变成了" %c"
,多一个空格就行了。
这个问题是因为scanf()
函数的问题。录入的第一个换行字符不是自动填充的,他是上一行末尾的换行符,
分配串空间成功,其地址为:4b0
请输入原串的长度:2
原串是否为空:0(1:是;0:否)
请逐个输入字符:1
2
请输入原串的长度:2
这一行在数字2
后还有一个换行字符,而scanf()函数中%c
对空白字符(空格、换行、制表符)
的处理和其它说明符不一样,它默认不会跳过空白字符,所以读取的时候先把换行读进来了。而在%c
前面加上一个空格就指示它跳过空白了。
C语言了scanf()
不是最常用的输入函数,逐字符读取建议使用 getchar()
。
建议说明一下程序是做什么的:程序期望什么输入,会产生什么输出。