NOIP2012 提高组 复赛 day1 vigenere vigenere密码
来源:互联网 发布:阿里云数据盘扩容 编辑:程序博客网 时间:2024/05/22 00:31
NOIP2012 提高组 复赛 day1 vigenere vigenere密码
1、经过《算法竞赛入门经典(第2版)》第三章 数组和字符串 的训练,此题几乎没费什么力,代码就写出了。
2、写代码过程中的一个失误是将输入读成密码,明文,输出为密文,改起来没费什么周折,只是将+改成-。
3、编译后,输出与预想的不一样,跟踪调试上花了点时间,很快就改好了。
4、输出结束后要不要回撤换行,斗争了小一会,最后决定加上,不然怎么判断是完整的一行呢。
5、经对拍对比,此题10个输入输出完全正确,100分。
编译环境Dev-C++4.9.9.2
附上代码:
#include <stdio.h>
#include <string.h>
char k[100+10],m[1000+10];
int main(){
int klen,mlen;
int i,j;
int pos;
char c;
FILE *fin,*fout;
fin=fopen("vigenere.in","rb");//文件打开
fout=fopen("vigenere.out","wb");
fscanf(fin,"%s%s",k,m);
klen=strlen(k);
mlen=strlen(m);
for(i=0;i<mlen;i++){
j=i%klen;
if(k[j]>='A'&&k[j]<='Z'){//大写字母
pos=k[j]-'A';//确定偏移位置
}else{//小写字母
pos=k[j]-'a';
}
if(m[i]>='A'&&m[i]<='Z'){//大写字母
c='A'+(m[i]-'A'-pos+26)%26;
fprintf(fout,"%c",c);
}else{//小写字母
c='a'+(m[i]-'a'-pos+26)%26;
fprintf(fout,"%c",c);
}
}
putchar('\n');//换行
fclose(fin);
fclose(fout);//文件关闭
return 0;
}
- NOIP2012 提高组 复赛 day1 vigenere vigenere密码
- NOIP2012提高组day1 vigenere密码 题解
- NOIP 2013 提高组复赛 day1 试题 Vigenere密码
- 【Noip2012】Vigenere密码
- noip2012 vigenere密码 (模拟)
- Vigenere密码
- Vigenere密码
- NOIP2012 提高组 复赛 day1 game
- Vigenere密码 Hill密码
- 破解 维吉尼亚(vigenere) 密码
- 密码程序之vigenere
- Vigenere 密码破译
- Vigenere密码 Python实现
- P1778 vigenere密码
- NOIP 2012 Vigenere 密码
- NOIP2012 提高组 复赛 day1 game 国王游戏 再见
- NOIP2012复赛提高组day1(A:Vigenère 密码 B:国王游戏 C:开车旅行)
- NOIP2012提高组Day1
- .net中URL重写
- leetcode刷题,总结,记录,备忘 383
- 使用ThreadLocal准确找到操作线程的对象
- 操蛋的博客我也是醉了,绑定账号爆炸了。
- Caffe学习:Blobs, Layers, and Nets
- NOIP2012 提高组 复赛 day1 vigenere vigenere密码
- svn在commit的错误信息:is scheduled for addition, but is missing
- 欢迎使用CSDN-markdown编辑器
- React-Native学习指南
- 二部图最大匹配--匈牙利算法
- 【Linux开发】【Qt开发】嵌入式Qt程序使用触屏或USB鼠标方式
- 大数据时代--Hive之开始动手(导入数据、查询、删除)
- 从零开始山寨Caffe·陆:IO系统(一)
- Android 线程+自制简易定时器