社区讨论
oj过了,这里8个re2个ac.
P1079[NOIP 2012 提高组] Vigenère 密码参与者 3已保存回复 3
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 3 条
- 当前快照
- 1 份
- 快照标识符
- @mi6non4p
- 此快照首次捕获于
- 2025/11/20 07:51 4 个月前
- 此快照最后确认于
- 2025/11/20 07:51 4 个月前
CPP
#include<bits/stdc++.h>
using namespace std;
int main()
{
char mi[1000],ki[100],ci[1000],a[100];
int b[1000];
cin>>ki>>ci;
strcpy(a,ki);
int lki=strlen(ki),lci=strlen(ci);
while(lki<lci)
{
strcat(ki,a);
lki=strlen(ki);
}
for(int i=0;i<lki;i++)
if(ki[i]>='a'&&ki[i]<='z') ki[i]-=32;
for(int i=0;i<lci;i++)
{
if(ci[i]>='A'&&ci[i]<='Z') b[i]=1;
else b[i]=0;
}
for(int i=0;i<lci;i++)
if(ci[i]>='a'&&ci[i]<='z') ci[i]-=32;
for(int i=0;i<lci;i++)
{
if(ci[i]-ki[i]<0) mi[i]=ci[i]+27-ki[i]+64;
else mi[i]=ci[i]+1-ki[i]+64;
}
int lmi=strlen(mi);
for(int i=0;i<lmi;i++)
{
if(b[i]==0) mi[i]+=32;
}
cout<<mi;
}
回复
共 3 条回复,欢迎继续交流。
正在加载回复...