|字符串反转字符串转数字|1086 就不告诉你 (15分)

//C++ reverse函数的用法

 //逆序(反转)无论是在C或是C++中用的都特别多,
 //常用于数组,字符串,容器等,其本身的函数参数也不复杂。

       //标准C中是没有recerse()函数的,这是C++的一个新增函数,使用需要包含头文件	
       #include <algorithm>
       //reverse函数用于反转在[first,last)范围内的顺序
       //(包括first指向的元素,不包括last指向的元素),reverse函数没有返回值


       //例如,交换vector容器中元素的顺序
		vector<int> v = {5,4,3,2,1};
		reverse(v.begin(),v.end());//v的值为1,2,3,4,5

       //还有string类的字符串
		string str="www.mathor.top";
		reverse(str.begin(),str.end());//str结果为pot.rohtam.wwww
		
		//交换字符数组char[]中元素的顺序
		char a[101] = “hello world”;
		reverse(a,a+strlen(a));
/*
atoi()和stoi()的区别----数字字符串的处理

相同点:
①都是C++的字符处理函数,把数字字符串转换成int输出
②头文件都是#include<cstring>
不同点:
①atoi()的参数是 const char* ,因此对于一个字符串str我们必须调用 c_str()的方法把这个string转换成 const char*类型的,而stoi()的参数是const string*,不需要转化为 const char*;
如图:

②stoi()会做范围检查,默认范围是在int的范围内的,如果超出范围的话则会runtime error!
如图:

 
而atoi()不会做范围检查,如果超出范围的话,超出上界,则输出上界,超出下界,则输出下界;
代码:*/
//myfirst.cpp--displays a message   
 
#include "stdafx.h"  
#include <iostream>  
#include <set>  
#include <string>  
using namespace std;
int main()
{
	string s1 = "2147482", s2 = "-214748";
	string s3 = "214748666666663", s4 = "-21474836488";
	cout << stoi(s1) << endl;
	cout << stoi(s2) << endl;
	cout << atoi(s3.c_str()) << endl;
	cout << atoi(s4.c_str()) << endl;
	return 0;
}


#include <sstream>
using namespace std;
int strToInt(string s){
    stringstream ss;
    ss<<s;
    int a;
    ss>>a;
    return a;
}

在这里插入图片描述

#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
int main() {
    int a, b;
    scanf("%d %d", &a, &b);
    string s = to_string(a * b);
    reverse(s.begin(), s.end());
    printf("%d", stoi(s));
    return 0;
}
//11分
// #include <iostream>
// //#include <stack>
// using namespace std;

// int main()
// {
//     int a, b;
//     cin>>a>>b;
//     int sum=a*b;
//     //stack<int> s;
//     //int cnt=0;
//     int arr[10010]={0},i=0;
//     while(sum!=0){
//         //s.push(sum%10);
//         arr[i++]=sum%10;
//         sum/=10;
//     }
//     for(int j=0;j<i;j++){
//         cout<<arr[j];
//     }
        
   
//    return 0;
// }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值