c - Vigenere 分段错误
问题描述
#include<stdio.h>
#include<cs50.h>
#include<string.h>
#include<ctype.h>
#include<stdlib.h>
int main(int argc, char** argv)
{
string p;
int c;
if (argc >= 2)
{
p = get_string("plaintext: ");
}
if (argc != 2 || isalpha(argv[1][0]) == false)
{
printf("ERROR\n");
return 1;
}
printf("ciphertext: ");
string k = argv[1];
int m = strlen(k);
for(int i = 0,j = 0, n = strlen(p); i < n; i++)
{
c = p[i] + k[j % m];
if(isupper(k[j % m]))
{
k[j % m] = k[j % m] - 'A';
}
if(islower(k[j % m]))
{
k[j % m] = k[j % m] - 'a';
}
if(isalpha(p[i]) == false)
{
printf("%c", p[i]);
}
if(islower(p[i]) && islower(c))
{
printf("%c", c);
j++;
}
if(isupper(p[i]) && isupper(c))
{
printf("%c",c);
j++;
}
if(isupper(p[i]) && !isupper(c))
{
c = ((c - 'A') % 26) + 'A';
printf("%c", c);
j++;
}
if(islower(p[i]) && !islower(c))
{
c = ((c - 'A') % 26) + 'A';
printf("%c",c);
j++;
}
else(printf("%c",c));
j++;
}
printf("\n");
}
我无法弄清楚我的代码有什么问题。当我尝试运行它时,我可以让它提示我输入明文,但如果我尝试更进一步,我会遇到分段错误。我相信这与我的 for 循环的开始有关?我不知道我c
是否正确声明了变量。除此之外,我真的没有任何线索。
[Thread debugging using libthread_db enabled]
Using host libthread_db library "/lib/x86_64-linux-gnu/libthread_db.so.1".
plaintext: hello
ciphertext:
Breakpoint 1, main (argc=2, argv=0x7fffffffdf18) at vigenere.c:24
24 for(int i = 0,j = 0, n = strlen(p); i < n; i++)
(gdb)
(gdb) n
26 if(isupper(k[j % m]))
(gdb)
30 if(islower(k[j % m]))
(gdb)
32 k[j % m] = k[j % m] - 'a';
(gdb)
35 c = p[i] + k[j % m];
(gdb)
37 if(isalpha(p[i]) == false)
(gdb)
41 if(islower(p[i]) && islower(c))
(gdb)
43 printf("%c", c);
(gdb)
h44 j++;
(gdb)
46 if(isupper(p[i]) && isupper(c))
(gdb)
51 if(isupper(p[i]) && isupper(c) == false)
(gdb)
57 if(islower(p[i]) && islower(c) == false)
(gdb)
65 (printf("%c",c));
(gdb)
h66 j++;
(gdb)
68 }
(gdb)
24 for(int i = 0,j = 0, n = strlen(p); i < n; i++)
(gdb)
26 if(isupper(k[j % m]))
(gdb)
30 if(islower(k[j % m]))
(gdb)
32 k[j % m] = k[j % m] - 'a';
(gdb)
35 c = p[i] + k[j % m];
(gdb)
37 if(isalpha(p[i]) == false)
(gdb)
41 if(islower(p[i]) && islower(c))
(gdb)
43 printf("%c", c);
(gdb)
g44 j++;
(gdb)
46 if(isupper(p[i]) && isupper(c))
(gdb)
51 if(isupper(p[i]) && isupper(c) == false)
任何人都可以解释为什么即使 if 语句是错误的, h 也会打印两次?我能够解决这个问题,但我仍然在努力弄清楚为什么 c 每次迭代都会输出不止一次。
解决方案
您可能会在此处获得特定问题的答案,但如果您想解决它并学习一些东西(这就是 cs50 的重点),请执行以下步骤:
- 首先尝试在没有任何帮助的情况下解决它,如果这不起作用,请执行下一步,
- 观看Zamyla 的演练,并尝试一步一步完成,
- 如果你有一个看起来太难的问题,离开电脑,拿起笔和一张纸,分析你的程序应该做什么,它实际上做了什么,
- 学习使用调试器(在 cloud9 cs50 IDE 中它位于屏幕右侧),
- 如果您的问题看起来非常非常困难,请关闭计算机并用笔和一张纸上床睡觉,您会惊讶地发现躺着解决问题是多么容易:)
当您应用这些步骤并解决您的问题时,您将获得一些解决类似问题的技能,并且您会感到很聪明:)
如果你是一个完全的编程初学者,那么前面会遇到一些非常棘手的问题(破解、拼写......),但如果你应用这些步骤,你可以解决所有问题。我知道,因为我做到了,而且我不是专家 C 程序员、超级聪明或其他什么,但我的“拼写”解决方案现在排在前 10 位。
请耐心等待,祝你好运:)
推荐阅读
- visual-studio-code - 使用“vscode.openFolder”打开工作区后如何获取新窗口的属性
- notepad++ - 我想删除唯一的括号 {36774343-CC45-4693-8F3A-F4EBAB6BB3C6}
- python - Python manage.py runserver 管理页面
- html - Nodejs:从 HTML 获取纯文本但保留有序和无序列表
- html - 在引导导航栏中彼此相邻制作下拉菜单
- bash - 从文件中提取两个模式之间的内容
- apache-spark-sql - 执行 Spark 提交命令时出现 Pydrill 堆内存问题
- php - 如何以 24 小时格式在 codeigniter 中获取当前日期时间
- java - Spring XML 在 bean 中使用注解
- javascript - 如何在不同的 javascript 数组中保存 JSON API 响应