A C program code that reverses an array.
Topic: Write a function to rearrange the digits of the incoming integer data in reverse order, for example: If 1278 is passed in, the function returns 8721; if -257 is passed in, the function returns -752; if 510 is passed in, the function returns The value is 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;
}
result: