社区讨论

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 条回复,欢迎继续交流。

正在加载回复...