字母越界情况。
(in[j]-‘a’+n)%26+‘a’
in[j]-‘a’:读入中对应的第几个字母的位置 c’对应2(0开始);
in[j]-‘a’+n:读入中对应字母加上转移位数得到的字母的对应位置
如如’c’这个字母移动3位,就是第二个字母向右移动3个,就是第五个,即’f’
取余26是防止移动位数超过26导致炸掉
再加上’a’,将对应位置还原字母,再打出来.
数字越界情况
j = (n + (j - s) % n) % n
j-s:当前位置-移动位数得到最终移动的位置
(j-s)%n:防止越界,取余数表示最终移动位置。
n+(j-s)%n:总长度-最后移动位置=从前面数位置是多少
(n+(j-s)%n):防止越界,数组下标是从0开始.