繁体   English   中英

为什么两个不相等的字母在 C 中显示为等价?

[英]Why do 2 letters not equal to each other show up as equivalent in C?

我正在制作一个对明文进行简单加密并输出加密密文的程序。 这是一个以YTNSHKVEFXRBAUQZCLWDMIPGJO为关键的示例。

$ ./substitution YTNSHKVEFXRBAUQZCLWDMIPGJO
plaintext:  HELLO
ciphertext: EHBBQ

如果您想了解更多信息,可以阅读此处的说明。

这是我的代码:

#include <cs50.h>
#include <stdio.h>
#include <ctype.h>
#include <string.h>

string ciphertext_generator(string key,string plaintext);
bool alphabetic_char_checker(string word);
bool alphabetic_char_repeat_checker(string word);


string alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";

int main(int argc, string argv[])
{
    if (argc != 2)
    {
        printf("Please enter a key\n ");
        return 1;
    }
    if (strlen(argv[1]) != 26)
    {
        printf("The key must contain 26 characters.\n ");
        return 1;
    }
    if (alphabetic_char_checker(argv[1]) == false)
    {
        printf("The key must only contain alphabetic characters.\n ");
        return 1;
    }
    else if (alphabetic_char_repeat_checker(argv[1]))
    {
        printf("The key must not contain repeated characters.");
        return 1;
    }


    string plaintext = get_string("plaintext: ");
    string ciphertext = ciphertext_generator(argv[1],plaintext);
    printf("ciphertext: %s",ciphertext);
    return 0;
}
string ciphertext_generator(string key,string plaintext)
{
    string ciphertext = plaintext;
    for (int i = 0, k = strlen(ciphertext); i < k; i++)
    {
        bool capital = isupper(ciphertext[i]);
        ciphertext[i] = toupper(ciphertext[i]);
        for (int i2 = 0, a = strlen(alphabet); i2 < a; i2++)
        {
            if (plaintext[i] == alphabet[i2])
            {
                if (capital == true)
                {
                    ciphertext[i] = key[i2];
                }
                else
                {
                    ciphertext[i] = tolower(key[i2]);
                }
            }
        }
    }
    return ciphertext;
}

bool alphabetic_char_checker(string word)
{
    for (int i = 0, w = strlen(word); i < w; i++)
    {
        word[i] = toupper(word[i]);
        if (word[i] < 'A' || word[i] > 'Z')
        {
            return false;
        }
    }
    return true;
}
bool alphabetic_char_repeat_checker(string word)
{
    for (int i = 0, w = strlen(word); i < w; i++)
    {
        word[i] = toupper(word[i]);
        for (int i2 = 0; i2 < w; i2++)
        {
            if (word[i] == word[i2])
            {
                return false;
            }
        }
    }
    return true;
}

我的问题在于ciphertext_generator function 接受密钥和明文并输出加密的密文。 这里发生的是它遍历明文中的所有字母,然后对于每个字母,它遍历整个字母表,检查明文中的字母是否在字母表中,并计算它在字母表中的哪个索引,然后是然后用作密钥的索引,然后在密文字符串中相应地替换。

这里的问题是,在明文的第一个字母上迭代字母表的每个字母,它在正确的索引 N 处正确找到并替换正确的字母,但它也替换了明文,而不仅仅是密文。

我不是想解决这个问题,只是想了解发生了什么,因为我已经调试过了。 接下来发生的事情是,第一个字母不断迭代字母表的 rest,直到找到 N,然后用字母表中的正确字母替换它,但也用明文替换。

**

问题

当我只设置密文时,为什么明文会捡起字母?

回答问题

当我只设置密文时,为什么明文会捡起字母?

在您的 function ciphertext_generator的第一行它说string ciphertext = plaintext; 此行表明密文变量将等于明文变量,这意味着密文的 memory 指向与明文相同的 memory,因此对密文所做的任何更改都将应用于明文。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM