一道简单的加密问题,用C++写的

问题:
编写一个简单加密程序。输入一个6位整数的明码,按以下方法加密:首先,将每位数字替换成它与7相加之和再用10求模的结果;然后逆置;最后输出密码。再编写程序,把这个密码还原成明码。若输入错误,则显示错误信息后退出程序。
例如,输入原码数据n为:200911,则显示密码n1为:886779,解密后的原码n2为:200911。
注:密码n1不一定是6位整数,但明码n和n2是相等的6位整数。
这是我写的代码,下面是运行结果,为什么不对呢?而且还是十六进制的
(https://img-ask.csdn.net/upload/201710/27/1509090484_339543.png)
(https://img-ask.csdn.net/upload/201710/27/1509090738_944382.png)

“将每位数字替换成它与7相加之和再用10求模的结果”,没明白这句话,你是把输入的数与7相加之后,再与10求模吗?还是什么?