算是比较水的题。字符没有很难的处理。但是看看自己的代码和神牛的代码,差距实在太大~
我的代码:
#include <iostream>
using namespace std;
bool is(string s)
{
int i,len;
len = s.size();
if(s[0] == 'R'&&(s[1]>='0'&&s[1]<='9'))
{
for(i = 2;i < len;i ++)
if(s[i]>='A'&&s[i]<='Z') return 1;
return 0;
}
else return 0;
}
int main()
{
int n,i,j,r,c,len;
string s,s1;
cin>>n;
while(n --)
{
cin>>s;
len = s.size();
if(is(s))
{
r = 0;
i = 1;
while(s[i]!='C')
{
r = r*10 + s[i] - '0';
i ++;
}
i ++;
c = 0;
while(i < len)
{
c = c*10 + s[i] - '0';
i ++;
}
s1 = "";
//cout<<r<<" "<<c<<endl;
while(c)
{
s1 += (c-1)%26;
c = (c-1)/26;
}
int l = s1.size();
for(i = l-1;i >=0;i --)
{
cout<<char(s1[i]+'A');
}
cout<<r<<endl;
}
else
{
c = 0;
r = 0;
for(i = 0;i < len;i ++)
{
if(s[i]>='A'&&s[i]<='Z') c = c*26+s[i]-'A'+1;
else break;
}
for(;i < len;i ++)
{
r = r*10+s[i]-'0';
}
cout<<"R"<<r<<"C"<<c<<endl;
}
}
}
某位神牛的代码:
#include<cstdio>
void g(int t){if(t){g((t-1)/26);putchar(65+(t-1)%26);}} //递归输出即可倒序
int main(){
int n,x,y;
char s[64],*p;
for(scanf("%d ",&n);n--;){
gets(s);
if(sscanf(s,"%*c%d%*c%d",&x,&y)==2){ //sscanf() - 从一个字符串中读进与指定格式相符的数据
g(y);
printf("%d\n",x);
}else{
for(x=0,p=s;*p>64;++p)
x=x*26+*p-64;
printf("R%sC%d\n",p,x);
}
}
return 0;
}
其实这里用到了sscanf()函数简化了很多代码!后面的字符串指针用法也很精髓~这是sscanf()函数的具体用法~很有用~
http://hi.baidu.com/stanver/blog/item/560a84822b776f99f603a6f9.html