error while compiling.

It is Caesar cipher code. I don't know where the problem is.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#include<iostream>
#include<string>

using namespace std;
class Caesar {
public:
	Caesar(int k);
	string encode(string me)
	{
		int i;
		for (i = 0; i < me.length(); i = i++) {
			me[i] = toupper(me[i]);
		}
		for (int i = 0; i < me.size(); ++i)
		{
			if (!((me[i] >= 'a' && me[i] <= 'z') || (me[i] >= 'A' && me[i] <= 'Z')))
			{
				me[i] = '\0';
			}
		}
		int j = 0;
		for (int i = 0; me[i]; i++) {
			if (me[i] != ' ') {
				me[j++] = me[i];
				me[j] = '\0';
			}
		}
		int k;
		string code = "";
		for (i = 0; i < me.length(); i++) {
			code += char(int(me[i] + k - 65) % 26 + 65);
			return code;

		}
		}
	string decode(string op) {
		int i,k;
		string code;
		string me = "";
		for (i = 0; i < code.length(); i++) {
			me += char(int(code[i] - k + 65) % 26 + 65);
			return me;
		}
	}
	int k;
	int changekey(int c) {
		int c=k;
		return k;
	}
};

int main(){
	char antwort;
	string me,code;
	int k,c;
	cout << "Do you want encode ?y/n\n";
	cin >> antwort;
	if (antwort == 'y' || antwort == 'Y') {
		cout << "Enter your message.\n";
		cin >> me;
		cout << "Enter the key.\n";
		cin >> k;
		string encode(string me);
		cout <<"Your code is: "<< code<<"\n";
	}
	else if(antwort=='n'||antwort=='N'){
		cout << "Enter your code.\n";
		cin >>code;
		cout << "Enter the key.\n";
		cin >> k;
		string decode(string code);
		cout << "Your message is: " << me<<"\n";
}
	cout << "Do you want to change the key?y/n\n";
	if (antwort == 'y' || antwort == 'Y') {
		cout << "Enter the new key.\n";
		cin >> c;
		int changekey(int c);
		string encode(string me);
		cout << "Your new code is:" << code;
		string decode(string code);
		cout << "Your message was:" << me;
		return 0;
		system("pause");
	}
	}


Last edited on
Please use code tags when posting code. See http://www.cplusplus.com/articles/jEywvCM9/
You can edit your post.

If you do get "error while compiling", then please show it. We cannot help you to learn to read the error messages that your compiler gives you unless you show us the messages you get.
@keskiverto is correct, it helps us to read your code and to know the error.

That said, I did notice (by pasting this into a compiler and trying it):

1
2
3
4
5
6
int k;
int changekey(int c) 
{
  int c=k;
  return k;
}


The complaint is telling you that c is a parameter, and then it is also declared as an integer inside the function (the first line of the function int c=k )

That said, I don't see what the plan is here. The input, c, is not used. Even if one removed the "int" in front of "c" in the function, that would assign the INPUT to k, then return k, doing nothing with c.

Should this be changing k to c with "k=c"?

no c to k
the errors are in the for loops and the function changekey
What do the errors say, exactly?

Do they look like:
 In member function 'std::string Caesar::encode(std::string)':
11:17: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
11:37: warning: operation on 'i' may be undefined [-Wsequence-point]
14:21: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
30:17: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]

 In member function 'std::string Caesar::decode(std::string)':
40:17: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]

 At global scope:
36:23: warning: unused parameter 'op' [-Wunused-parameter]

 In member function 'int Caesar::changekey(int)':
47:7: error: declaration of 'int c' shadows a parameter
47:7: warning: unused variable 'c' [-Wunused-variable]

 At global scope:
46:20: warning: unused parameter 'c' [-Wunused-parameter]

First, a "warning" does not actually abort compilation, even though it points to suspicious code.

comparison between signed and unsigned integer expressions

In i < me.length() the i is signed value and the string's length is unsigned. That could be apples to oranges situation (even though here it won't be).
Make the i unsigned, same type as me.length(). size_t i;

operation on 'i' may be undefined

What do you do here:
for (i = 0; i < me.length(); i = i++ ) // why?
In the other loops:
for (i = 0; i < me.length(); i++ )


How do you initialize the member k of class Ceasar?

unused parameter

A function takes a parameter, but does not use it. Ever.
What is the point of the parameter, if you don't need it?
Topic archived. No new replies allowed.