数字反转(C++)

#include  
using namespace std;
int main()
{ 
	string  s;
	cin>>s; //endl是用来换行的,看实际使用 
	int length = s.size(),m = 0;
	char n;
	for(int i = 0;i < length;i ++)
	{
		if(!isdigit(s[i]))  //isdigit用来判断字符串是否只有数字构成 
		{
			n = s[i];
			m = i;
			break;
		}

	}
	
	if(!m)
	{
		while(s[length-1] == '0')
		length --;
		for(int i = length -1;i >= 0; i --)
		{
			cout << s[i];
		}
		if(length -1 < 0 )
		cout << "0"; 
	}
	else if(n == '.' || n  == '/')
	{
		int l = m -1;
		int r = m + 1;
		while(s[l] == '0') l --;
		for(int i = l; i>= 0;i --)
		cout << s[i];
		if(l < 0 )
		cout << "0";
		cout << n;
		if(n == '.')
		{
			while(s[r]=='0')
			r ++;
		}
		else while(s[length -1] == '0')
		length --;
		for(int i = length -1;i >= r;i --)
		{
			cout << s[i];
		}
		if(r == length )
		cout << "0";
	}
	
	return 0;
}

给大嘴猫一个数(整数、小数、分数),让它找出该数的反转。

  • 整数反转是将所有数位对调。

  • 小数反转是把整数部分的数反转,再将小数部分的数反转,不交换整数部分与小数部分。

  • 分数反转是把分母的数反转,再把分子的数反转,不交换分子与分母。

你可能感兴趣的:(C/C++,蓝桥杯,c++,拓扑学)