正如标题所述,该程序的目的是将一串莫尔斯代码(例如.- / .- / .-)加入到一个字符数组中。我相信我几乎就在那里,但是我需要能够将morsecat
设置为空,因为我相信为什么程序无法正常运行是因为morsecat
不断接收字符,当谈到将morsecat中保存的内容转换为字符时,它会发现morsecat太长并且无法转换它,因为它与任何莫尔斯字符不匹配,因为它包含两个或更多莫尔斯字符而不是一个(这就是为什么while while循环是" /"分隔每个莫尔斯字符)。
我附上了我的代码,但如果您认为它需要的话,请随时彻底检查它。
任何帮助都会非常感激,因为这让我有点难过了。
注意:我知道当你尝试验证代码时它会给出错误"空字符常量",因为我不知道如何重置morsecat的值以使其不包含任何内容。
以下程序代码:
char * ip = ".-/.-/";
char buf[50];
int buflen;
char morse2char (char * m) {
if (strcmp(m, ".-") == 0) {
Serial.println("a");
}
else if (strcmp(m, "-...") == 0) {
Serial.println("b");
}
else if (strcmp(m, "-.-.") == 0) {
Serial.println("c");
}
else if (strcmp(m, "-..") == 0) {
Serial.println("d");
}
else if (strcmp(m, ".") == 0) {
Serial.println("e");
}
else if (strcmp(m, "..-.") == 0) {
Serial.println("f");
}
else if (strcmp(m, "--.") == 0) {
Serial.println("g");
}
else if (strcmp(m, "....") == 0) {
Serial.println("h");
}
else if (strcmp(m, "..") == 0) {
Serial.println("i");
}
else if (strcmp(m, ".---") == 0) {
Serial.println("j");
}
else if (strcmp(m, "-.-") == 0) {
Serial.println("k");
}
else if (strcmp(m, ".-..") == 0) {
Serial.println("l");
}
else if (strcmp(m, "--") == 0) {
Serial.println("m");
}
else if (strcmp(m, "-.") == 0) {
Serial.println("n");
}
else if (strcmp(m, "---") == 0) {
Serial.println("o");
}
else if (strcmp(m, ".--.") == 0) {
Serial.println("p");
}
else if (strcmp(m, "--.-") == 0) {
Serial.println("q");
}
else if (strcmp(m, ".-.") == 0) {
Serial.println("r");
}
else if (strcmp(m, "...") == 0) {
Serial.println("s");
}
else if (strcmp(m, "-") == 0) {
Serial.println("t");
}
else if (strcmp(m, "..-") == 0) {
Serial.println("u");
}
else if (strcmp(m, "...-") == 0) {
Serial.println("v");
}
else if (strcmp(m, ".--") == 0) {
Serial.println("w");
}
else if (strcmp(m, "-..-") == 0) {
Serial.println("x");
}
else if (strcmp(m, "-.--") == 0) {
Serial.println("y");
}
else if (strcmp(m, "--..") == 0) {
Serial.println("z");
}
else if (strcmp(m, "/") == 0) {
Serial.println(" ");
}
}
char * charstring2morsestring(char * ip, char * buf, int buflen){
char backslash = '/';
char * currentchar;
int i;
char morsecat[buflen];
//morsecat[0] = '\0';
char * temp;
for(i=0;i<strlen(ip);i++){
do {
*temp = ip;
strcat(morsecat, temp);
//Serial.println(morsecat);
} while (ip != '/');
if (ip == '/') {
*currentchar = morse2char(morsecat);
strcat(buf, currentchar);
morsecat[buflen] = ' ';
}
}
Serial.println(buf);
}
void setup(){
Serial.begin(9600);
//Serial.println(morse2char(".-"));
//Serial.println(morse2char("-..."));
//Serial.println(morse2char("--.."));
charstring2morsestring(".-/-.../--../.", buf, 50);
}
void loop(){
}
答案 0 :(得分:0)
这看起来不像c
代码。但是,从逻辑角度来看,首先应该
*temp = ip;
错了,也许你想要的是temp = ip;
(ip != '/');
您不能将==
用于字符串comaprison。使用strcmp()
。*currentchar = morse2char(morsecat);
但我无法发现morse2char()
返回任何内容。并且您的代码中存在更多逻辑问题,例如无效的do..while
循环和所有。