CF 1B Spreadsheet

原创 2012年03月28日 20:12:30

算是比较水的题。字符没有很难的处理。但是看看自己的代码和神牛的代码,差距实在太大~

我的代码:

#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



            
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

CF1B Spreadsheet

一道字符串相关的比较水的题目。。不过调试无数次后才AC,,,果然我思维还是不够缜密比较水。。 #include using namespace std; int typeJudge(string s...

Codeforces 1B - Spreadsheet

这道题AC的不容易啊,唉,小错误频出,查看测试数据好多才改过来的。 首先注意的是两种类型属于哪一种的判断,利用第一个字符R和第二个字符是数字,还有后面存在字符C,这三个条件来判断。 然后注意的就是...

【CodeForces】[1B]Spreadsheet

转换类的题目 难度还是有些的 不过一点一点写 感觉还好 可以当作26进制来方便思考转换

Codeforces Beta Round #1 B Spreadsheet

http://codeforces.com/contest/1/problem/B分析: 这题是告诉你一种编码的方式, 有两种码,需要做的就是把一种形式的码转换成另一种形式的码。 首先需要判断是...

16CF1--B-1002

It's the end of July – the time when a festive evening is held at Jelly Castle! Guests from all over...

CF 134 DIV1 B.Blackboard Fibonacci

转载请注明出处,谢谢 http://blog.csdn.net/ACM_cxlove?viewmode=contents           by---cxlove 果然是暴跌RATE...

[KMP][字符串Hash] #93 div1 cf 126B Password

ACM kmp 字符串Hash

CF_Round274_Div1_B_Long Jump_二分搜索

突然发现区域赛好难。。。。再不好好训练就要打铁了。。。。。。。 ti yi

[二分] cf 768B Code For 1

二分题目

Spreadsheets_CF 1B

题目 题目链接 In the popular spreadsheets systems (for example, in Excel) the following numeration of colu...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)