我即将加密文本字符串,使用另一个文本字符串作为加密的“密钥”。它基本上只是对ASCII字符的重组。
密钥被给出并且结构很糟糕,需要一些额外的编程。此密钥中列出了ASCII字符,每行有一个字符,相应的加密字符有两个索引。
这是“key.txt”的例子:
A g
B 9
C ü
D (
E z
...继续所有ASCII字符。因此,我的程序中的加密将导致:
"EDABEDA" -> "z(g9z(g"
当我进行加密时。
我让程序接受输入字符串,然后使用加密密钥字符创建另一个字符串。
我使用for-sling遍历输入字符串中的每个字符。对于输入字符串中的每个字符,我检查加密密钥字符串中是否存在匹配的字符。在加密密钥中,我一次跳4个步骤,因为我要加密,只需要比较A,B,C,D ......
我使用strcmp()来查找匹配项。当匹配时,当输入字符串中的字符与加密密钥中的字符相同时,我将加密字符写入输出字符串。加密字符放在键字符串主字符前面的两个索引处。
警告发生在strcmp()
以下是代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define SIZE 3000
void encryption(char *input);
int main()
{
char input[] = "EDABEDA";
encryption(input);
}
void encryption(char *input)
{
int length,i,k;
size_t result;
char dicc[1000];
char output[SIZE];
FILE *f;
f = fopen("key.txt","r");
fseek(f, 0, SEEK_END);
length = ftell(f);
fseek(f, 0, SEEK_SET);
result = fread(dicc, 1, length, f);
int lenDic = strlen(dicc);
int lenInp = strlen(input);
for (i = 0 ; i < lenInp ; i++)
{
for (k = 4 ; k < lenDic ; k = k + 4)
{
if (strcmp(input[i],dicc[k]) == 0)
{
output[i] = dicc[k+2];
printf("%c",output[i]);
}
}
}
fclose(f);
}
我收到以下警告,该程序无效。有谁可以帮我解决这个严格警告并知道如何重新安排我的程序以满足其要求?
warning: passing argument 1 of ‘strcmp’ makes pointer from integer without a cast [enabled by default]
if (strcmp(input[i],dicc[k]) == 0)
^
In file included from crypt.c:3:0:
/usr/include/string.h:144:12: note: expected ‘const char *’ but argument is of type ‘char’
extern int strcmp (const char *__s1, const char *__s2)
^
warning: passing argument 2 of ‘strcmp’ makes pointer from integer without a cast [enabled by default]
if (strcmp(input[i],dicc[k]) == 0)
^
In file included from crypt.c:3:0:
/usr/include/string.h:144:12: note: expected ‘const char *’ but argument is of type ‘char’
extern int strcmp (const char *__s1, const char *__s2)
^
答案 0 :(得分:2)
使用strcmp()
来比较字符串,而不是字符。对于你的情况这个
if (input[i] == dicc[k])
应该有用。
不是char
只是整数类型而不是字符串类型,c中没有字符串类型。还有一件事,写出安全的代码!检查fopen()
是否成功,以及length
是否超过999
。几乎所有可以被视为错误的东西。