CF 1B Spreadsheet

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

我的代码:

#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


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: spreadsheetcontrol1是一款功能强大的电子表格控件,它具有多种功能和用途。其中一个功能是可以用来放置制作模板。 制作模板是常用的工作流程之一,它可以帮助我们在需要重复使用某种格式的文档时,节省时间和精力。通过使用spreadsheetcontrol1,我们可以轻松地创建自定义的模板,并在需要时进行使用和修改。 首先,我们可以利用spreadsheetcontrol1的电子表格功能,设置好模板的基本结构和格式。可以添加表头、行、列,并设置它们的样式和属性,以及单元格的数据格式和计算公式等。通过灵活的设置,我们可以根据具体的需求,制作出各种类型的模板,如财务报表、数据统计表、日程安排表等。 其次,spreadsheetcontrol1还支持文本和图像的插入,这也为制作模板提供了更多的可能性。我们可以在模板中插入公司的标志或品牌图片,以增加专业性和个性化。同时,我们还可以插入特定的文本说明或提示,以便用户更好地理解和使用模板。 最后,spreadsheetcontrol1还提供了保存和导出模板的功能。我们可以将制作的模板保存为标准的电子表格文件,如Excel文件,以便在任何时候进行查看和使用。此外,我们还可以导出模板为PDF或图片文件,以方便在其他平台或设备上使用。 总之,通过spreadsheetcontrol1,我们能够方便地放置制作好的模板,并根据需要进行调整和修改。它为我们提供了丰富的功能和灵活的操作方式,使模板制作变得简单高效。无论是在个人生活还是工作中,都可以通过spreadsheetcontrol1轻松地处理各种模板需求。 ### 回答2: SpreadsheetControl1是一款用于创建、编辑和管理电子表格的控件。在使用该控件时,可以通过放置模板来快速搭建电子表格的结构和格式。 放置模板是将预先设计好的电子表格模板文件加载到SpreadsheetControl1中。这些模板文件可以提前创建,包含了特定的表格结构、公式、格式和样式等信息。通过放置模板,可以使得创建电子表格的过程更加高效和一致。 首先,需要确保已经将模板文件保存在适当的位置,可以是本地计算机的硬盘中,也可以是网络上的共享目录。然后,在使用SpreadsheetControl1时,通过指定模板文件的路径或名称,将其加载到控件中。 一旦模板文件被加载到SpreadsheetControl1中,用户可以开始在表格中填写数据、设置公式、应用格式等操作。同时,模板中的固定内容和格式也会被保留下来,使得电子表格的结构和样式始终保持一致。 通过放置模板,不仅可以提高工作效率,减少了重复操作的时间和精力,还可以确保电子表格的一致性和标准化。此外,放置模板还可以方便地实现数据的导入和导出,与其他系统或软件的数据交互。 总之,SpreadsheetControl1的放置模板功能是一种便捷的方法,可以快速创建具有特定结构和格式的电子表格。它提供了一种高效、统一和灵活的方式来管理和处理表格数据。 ### 回答3: spreadsheetControl1是一个用于操作电子表格的控件。它提供了一种简单而强大的方式来创建、编辑和管理电子表格。使用spreadsheetControl1,我们可以创建各种模板,以便在处理大量数据时进行快速和准确的分析。 在spreadsheetControl1中创建模板非常简单。首先,我们可以使用控件提供的各种工具和功能来设计电子表格的布局和格式。我们可以选择合适的行和列,定义它们的宽度和高度,并应用各种样式和格式设置,如字体、颜色和边框等。 然后,我们可以使用spreadsheetControl1的功能来填充电子表格模板。我们可以在特定的单元格中输入文本、数字或公式。通过在单元格之间进行复制和粘贴,我们可以快速地填充大量数据。我们还可以使用函数和公式来进行复杂的计算,并使用条件格式设置来突出显示满足特定条件的数据。 一旦我们完成了模板的设计和填充,我们可以使用spreadsheetControl1提供的导出功能将电子表格保存为各种格式,如Excel、PDF和CSV等。这样,我们就可以轻松地与他人共享和传递我们创建的模板。 总之,spreadsheetControl1是一个功能强大的控件,可以帮助我们创建和管理电子表格模板。它提供了丰富的布局和格式设置选项,并支持各种数据填充和计算功能。通过使用spreadsheetControl1,我们可以更高效地处理大量数据,并为数据分析和管理提供准确和可靠的工具。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值