首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Modulo对文本进行换行

使用Modulo对文本进行换行
EN

Stack Overflow用户
提问于 2014-03-11 23:18:02
回答 2查看 140关注 0票数 0

我正在尝试使用字符串键加密一些纯文本。无论如何,如果纯文本大于密钥,则密钥将继续使用密钥。我使用了模数来使密钥重新开始,但由于某种原因,这不是working...what错误的代码?顺便说一句,键状态高或低不是一个因素,所以这就是为什么我把它改成低。任何提供的帮助都将不胜感激。//已按照建议清理代码。

代码语言:javascript
复制
#include <stdio.h>
#include <cs50.h>
#include <string.h>
#include<stdlib.h>
#include<ctype.h>

int main (int argc, string argv[])

{


if (argc != 2)
{

  printf("Ouch missing key\n");

return 1;
}

//get encryption keyword from argv array
string k= (argv[1]); 

//test for non aplha character in plain text message

int x;

for (x = 0; x <strlen(argv[1]); x++)
        {

    if(isalpha(k[x]) == false)

        {
printf("Ouch ensure value is alphabetical only\n");

return 1;

        }
  }

string m;


m = GetString(); //get plain text from prompt


for (int i= 0, j = 0; i< strlen(m) && j<= strlen(k); i++, j++)


{

    if (

        isalpha(m[i]) && isupper(m[i]))

            {

                m[i]= (m[i]-'a' + (tolower(k[j % strlen(k)])-'a')) % 26 + 'A';

            } 

    else if (

        isalpha(m[i]) && islower(m[i])

        )
            { 

           m[i] = (m[i] - 'a' + (tolower(k[j %strlen(k)])- 'a')) % 26 + 'a';


            }

    else 
         m[i] = m[i];
}

printf("%s\n", m);

}
EN

回答 2

Stack Overflow用户

发布于 2014-03-12 06:38:29

代码语言:javascript
复制
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <ctype.h>
#include <cs50.h>

int main (int argc, string argv[]){
    if (argc != 2){
        printf("Ouch missing key\n");
        return 1;
    }
    string k = argv[1];
    int len_k = strlen(k);

    for (int i = 0; i < len_k; ++i){
        if(isalpha(k[i]))
            k[i] = tolower(k[i]);
        else {
            printf("Ouch ensure value is alphabetical only\n");
            return 1;
        }
    }

    string m;
    m = GetString();

    for (int i= 0; i< m[i] ; ++i){
        if(isupper(m[i]))
            m[i]= (m[i]-'A' + k[i % len_k] - 'a') % 26 + 'A';
        else if(islower(m[i]))
            m[i]= (m[i]-'a' + k[i % len_k] - 'a') % 26 + 'a';
        else 
            m[i] = m[i];//no effect, no need
    }

    printf("%s\n", m);
    free(m);
    return 0;
}
票数 1
EN

Stack Overflow用户

发布于 2014-03-11 23:22:08

如果您编码语言是C修复main() by,

int main (int argc, string argv[])

int main (int argc, char * argv[])

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22329908

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档