概述
题目;
以下为原题面,仅供参考
给定一个数,请将该数各个位上数字反转得到一个新数。
这次与NOIp2011普及组第一题不同的是:这个数可以是小数,分数,百分数,整数。整数反转是将所有数位对调;小数反转是把整数部分的数反转,再将小数部分的数反转,不交换整数部分与小数部分;分数反转是把分母的数反转,再把分子的数反转,不交换分子与分母;百分数的分子一定是整数,百分数只改变数字部分。整数新数也应满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零;小数新数的末尾不为0(除非小数部分除了0没有别的数,那么只保留1个0);分数不约分,分子和分母都不是小数(约分滴童鞋抱歉了,不能过哦。输入数据保证分母不为0),本次没有负数
题目描述
给定一个数,请将该数各个位上数字反转得到一个新数。
这次与NOIp2011普及组第一题不同的是:这个数可以是小数,分数,百分数,整数。
整数反转是将所有数位对调。
·小数反转是把整数部分的数反转,再将小数部分的数反转,不交换整数部分与小数部分。
分数反转是把分母的数反转,再把分子的数反转,不交换分子与分母。
百分数的分子一定是整数,百分数只改变数字部分。
输入格式一个数s
输出格式
一个数,即s的反转数
输入输出样例
输入 #1 复制 输出 #1 复制
5087462 2647805
输入 #2 复 输出 #2 复制
600.084 6.48
复制
复制
输入 #3 输出 #3
700/27 7/72
输入 #4 复制 输出 #4
复制
8670% 768%
说明/提示
所有数据:25%s是整数,不大于20位
25%s是小数,整数部分和小数部分均不大于10位
25%s是分数,分子和分母均不大于10位
25%s是百分数,分子不大于19位
(20个数据)数据保证:
对于整数翻转而言,整数原数和整数新数满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数和原来的数字的最高位数字不应为零。
。对于小数翻转而言,其小数点前面部分同上,小数点后面部分的形式,保证满足小数的常见形式,也就是末尾没有多余的0(小数部分除了0没有别的数,那么只保留1个0。若反转之后末尾数字出现0,请省略多余的0)
对于分数翻转而言,分数不约分,分子和分母都不是小数。输入的分母不为0。与整数翻转相关规定见上。
对于百分数翻转而言,见与整数翻转相关内容。
数据不存在负数。
代码如下:
#include <stdio.h>
#include <math.h>
#include <string.h>
void reverse(char str[],int len); //逆序字符串
void print(char str[],int len,int mid); //输出字符串
int check(char str[],int len); //盘算字符串的类型是分数,小数,还是整数
int main()
{
int mid;
char str[100];
scanf("%s",str);
int len=strlen(str);
mid=check(str,len);
print(str,len,mid);
}
int check(char str[],int len)
{
int mid,flag=1;
for(int i=0;i<len;i++)
{
if(str[i]=='/') //分数
{
reverse(str,len);
mid=i;
flag=0;
}
if(str[i]=='.') //小数
{
reverse(str,len);
mid=i;
flag=0;
}
if(str[i]=='%') //百分数
{
reverse(str,len);
mid=i;
flag=0;
}
}
if(flag) //整数
{
reverse(str,len);
mid=len;
}
return mid; //返回字符所在字符串的位置
}
void print(char str[],int len,int mid)
{
int len1=len-mid,len2=0,len3=len-mid-2;
do{ //去除小数点前部分的零
if(str[len1]=='0')
{
len1++;
}
}while(str[len1]=='0');
for(int i=0;i<len;i++) //去除小数部分无效的零
{
if(str[i]=='.')
{
do{
if(str[len3]=='0')
{
len3=len3-1;
}
}while(str[len3]=='0'); //去零
}
}
do{
if(str[len2]=='0')
{
len2++;
}
}while(str[len2]=='0'); //输出
for(int i=len1;i<=len;i++)
{
printf("%c",str[i]);
}
printf("%c",str[len-mid-1]);
for(int i=len2;i<len3+1;i++)
{
printf("%c",str[i]);
}
}
void reverse(char str[],int len)//逆序
{
char m;
for(int i=0,j=len;i<len/2;i++,j--)
{
m=str[i];
str[i]=str[j-1];
str[j-1]=m;
}
}
代码有点长。
中间的地方可以加一个函数,但是能力有限,没加进去。
最后
以上就是朴实玫瑰为你收集整理的学习c语言练习题的全部内容,希望文章能够帮你解决学习c语言练习题所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复