大家好,又见面了,我是你们的朋友全栈君。
一个C语言程序代码,反转数组。
题目:编写一个函数,实现传入的整型数据各位数字的逆序重排,比如: 传入 1278,函数返回值为 8721;传入-257,函数返回值为-752;传入 510,函数返回值为 15。
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#define maxArraySize 100 //定义数组最大长度,防止输入的整型数据超出int表示的范围
int inverseIntArray(int inputArray[maxArraySize], int length); //声明逆序函数
int main()
{
int i;
int temp; //定义一个中间变量
int sign; //定义正负数的标志
int digit; //定义传入整数的位数
int remainder;
int result;
int inputNumber; //定义输入的整数
int integerArray[maxArraySize]; //定义将输入整数转换为的整型数组
printf("请输入你要传入的整型数据:");
scanf("%d", &inputNumber);
if(inputNumber<0) //判断如果是复数就做标记后将复数取为相反数
{
sign = 1;
inputNumber = -inputNumber;
}
temp = inputNumber;
for(digit=0;temp>=1;digit++) //循环求输入整数的位数
{
temp = temp/10;
}
temp = inputNumber;
for(i=0;i<digit;i++) //将输入的整型数据转换为整型数组
{
remainder = temp%10; //取余获取每一位的数的大小
integerArray[digit-i-1] = remainder;
temp = temp/10;
}
result = inverseIntArray(integerArray,digit); //调用逆序排列函数
if(sign==1)
{
printf("\n逆序排列后的结果为:-%d",result); //输入为负数输出添负号
}
else
{
printf("\n逆序排列后的结果为:%d",result); //输入为正数
}
}
int inverseIntArray(int inputArray[maxArraySize], int length)
{
int i = 0;
double temp; //定义一个中间变量防止精度损失
int outputArray[maxArraySize];
int outputNumber = 0;
for(i=length-1;i>=0;i--) //将输入的整型数组逆序排列
{
outputArray[length-1-i] = inputArray[i];
}
for(i=0;i<length;i++) //将逆序排列后的数组转换为整型数
{
temp = pow(10.0,(length-i-1)); //pow()函数的参数和返回值都为double类型,如果传入int会出现精度损失
outputNumber = outputNumber + outputArray[i]*((int)temp); //3位数时会出现输出减一的情况就是因为损失了精度
}
return outputNumber;
}
结果:
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/134193.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...