这个程序为啥报错,求大佬解释!
#include <stdio.h>#include <string.h>
#define HEIGHT 7
const char *letters[] = {
"\
\########@\
\## @\
\## @\
\######@\
\## @\
\## @\
\## @\
",
"\
\####@\
\ ## @\
\ ## @\
\ ## @\
\ ## @\
\ ## @\
\####@\
",
"\
\ ###### @\
\## ##@\
\## @\
\ ###### @\
\ ##@\
\## ##@\
\ ###### @\
",
"\
\## ##@\
\## ##@\
\## ##@\
\#########@\
\## ##@\
\## ##@\
\## ##@\
",
"\
\ ###### @\
\## ##@\
\## @\
\## @\
\## @\
\## ##@\
\ ###### @\
"
};
int main()
{
int i, j;
int gap;
printf("请输入字母的间隔(空格数):");
scanf("%d", &gap);
// 一行一行打印
for (i = 0; i < HEIGHT; i++)
{
// 打印所有字母的某一行
for (j = 0; j < 5; j++)
{
// k 用于迭代每一行的‘#’字符
int k = 0;
// 计算出该字母每一行有多少个字符
int len = strlen(letters) / HEIGHT;
// 计算当前打印第几行
int line = i * len;
// @标志着该行结束
while (letters != '@')
{
putchar(letters);
k++;
}
int temp = gap;
while (temp--)
{
putchar(' ');
}
}
putchar('\n');
}
return 0;
} 本帖最后由 jackz007 于 2020-2-22 19:00 编辑
问题出在下面的字符数组定义和初始化语句
const char *letters[] = {
"\
\########@\
\## @\
\## @\
\######@\
\## @\
\## @\
\## @\
",
"\
\####@\
\ ## @\
\ ## @\
\ ## @\
\ ## @\
\ ## @\
\####@\
",
"\
\ ###### @\
\## ##@\
\## @\
\ ###### @\
\ ##@\
\## ##@\
\ ###### @\
",
"\
\## ##@\
\## ##@\
\## ##@\
\#########@\
\## ##@\
\## ##@\
\## ##@\
",
"\
\ ###### @\
\## ##@\
\## @\
\## @\
\## @\
\## ##@\
\ ###### @\
"
};
每行开头的转义字符惹的祸,删掉就好了。
const char *letters[] = {
"\
########@\
## @\
## @\
######@\
## @\
## @\
## @\
",
"\
####@\
## @\
## @\
## @\
## @\
## @\
####@\
",
"\
###### @\
## ##@\
## @\
###### @\
##@\
## ##@\
###### @\
",
"\
## ##@\
## ##@\
## ##@\
#########@\
## ##@\
## ##@\
## ##@\
",
"\
###### @\
## ##@\
## @\
## @\
## @\
## ##@\
###### @\
"
};
字符 '\' 在 C 语言中是转义字符,与后续字符有固定搭配,比如,'\\' 代表 '\' 字符本身,'\t' 代表 TAB 字符 ,'\n' 代表换行字符,'\r' 代表回车字符,'\012' 代表换行字符,'\x0a' 代表换行字符...,等等。而 '\#' 并不属于预设的有效搭配,所以,编译器就会报错。 jackz007 发表于 2020-2-22 18:42
问题出在下面的字符数组定义和初始化语句
每行开头的转义字符惹的祸,删掉就好了。
谢谢您
页:
[1]