蓝桥杯真题01求和

“求和”:来自2019 【第十届蓝桥杯省赛】 C/C++ C组

题目描述:
小明对数位中含有 2、0、1、9 的数字很感兴趣,在 1 到 40 中这样的数包 括 1、2、9、10 至 32、39 和 40,共 28 个,他们的和是 574。
请问,在 1 到 2019 中,所有这样的数的和是多少?

需要的知识,字符串和数字的格式转换,字符串中有无出现某一字符的判断
如果此题不转为字符串的话,要进行求余取个位数太麻烦了!!
还是乖乖学点新东西:如何用自带函数将数字转为字符串!!
一些知识准备如下:
!!!
c++数字和字符串的转换
1 、利用stringstream
添加头文件 #include
数字转字符串:
#include
#include
int main(){
double a = 123.32;
string res;
stringstream ss; 定义流ss
ss << a; 将数字a转化成流ss
ss >> res; 将流ss转化成字符串
return 0;
}

。。。。。。。。。。。。。。。。。。。。。。。。

字符串转数字:
#include
#include
int main(){
double a ;
string res= “123.32”;
stringstream ss;
ss << res;
ss >> a;
return 0;
}

//此处包装了一个方法,将一位的数字转化成两位的字符串: //0->“00” 1->’'01"
string transform(int num)
{
string res;
stringstream ss;
ss<<num;
ss>>res;
if(num<10)
{
res=“0”+res;
}
return res;
}
。。。。。。。。。。。。。。。。。。。。。。。。

2.利用 sprintf()函数和sscanf()函数
sprintf() 用于将数字转化为字符串:
#include
#include
using namespace std;
int main()
{
char str[10];
int a=1234321;
//将整数转化为字符串
sprintf(str,"%d",a);
int len=strlen(str);
cout<<“字符串”<<str<<endl;
cout<<“长度”<<len<<endl;

char str1[10];
double b=123.321;
/ /将浮点数转化为字符串
sprintf(str1,"%.3lf",b);
int len1=strlen(str1);
cout<<"字符串"<<str1<<endl;
cout<<"长度"<<len1<<endl;
return 0;

}

。。。。。。。。。。。。。。。。。。。。。。。

sscanf() 用于将字符串转化为数字
#include
#include
using namespace std;
int main()
{
char str[]=“1234321”;
int a;
sscanf(str,"%d",&a);
cout<<a<<endl;
char str1[]=“123.321”;
double b;
sscanf(str1,"%lf",&b);
cout<<b<<endl;
return 0;
}

代码:

#include<iostream>
#include<algorithm>
#include<sstream>//定义stringstream函数 
using namespace std;
int main()
{
	long long sum=0;
	for(int i=1;i<=2019;i++)
	{
		//以下操作的意思是:
		//将i数字转为s字符串来判断s中有没有出现2019字符串中的任意一个字符
		 
		string s;
		stringstream ss;
		ss<<i;
		ss>>s;
		if(s.find_first_of("2019")!=string::npos)
		{//此函数规定如果没找到的话就返回string::npos 
			sum+=i;
		}
	}
	cout<<sum<<endl;
	return 0;
 } 

答案:1905111

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值