每日一题
题目:C语言:正整数、小数、字符串如何逆序输出
算法思想:
- 思路一:如果只是在做基础题时,可以用C语言小白逆序,仅仅使用
scanf
和printf
即可 - 思路二:利用数组,将字符串进行逆序输出。
- 思路三:可以通过将str数组的第1个字符和第n个字符交换位置,第二个和第n-1个交换…实现该功能
- 思路四:问题解决的难点在于找到数据的存放地址,通过不断地取余和整除 10 来得到数据的每一位。为了实现数据的逆序存放,每一次整除 10 的时候,同时把存放数据的数组地址后移,这样得到的第一位数存放在数组的最后一位……通过依次前移,即递归的回归,实现整个数据的存放。
一、程序代码:(思路一)
#include<stdio.h>
int main(){
char a,b,c,d;//定义略
scanf("%c%c%c.%c",&a,&b,&c,&d);
printf("%c.%c%c%c",d,c,b,a);
return 0;
}
运行结果:
123.4
432.1
注意:
在这里,代码中加了小数点,是为了需要输出小数点的时候,可以自行去掉。
二、程序代码:(思路二)
#include <stdio.h>
#include <string.h>
int main(){
char c[17];
int i;
scanf("%s", c);
for(i = strlen(c) - 1; i >= 0; i--){
printf("%c", c[i]);
}
return 0;
}
或者利用函数,同样可以利用数组来解决
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void Reverse(char str[], char res[]) {
int n = strlen(str);
int i;
for(i = 0; i <= n; i++){
res[i]=str[n - i - 1];
}
}
int main(){
char str[100];
char res[100];
gets(str); //比scanf简洁
Reverse(str, res);
printf("%s", res);
}
运行结果:
123.4
4.321
abcefg
gfecba
三、程序代码:(思路三)
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void Reverse(char str[]){
int n = strlen(str);
int i;
char temp;
for(i = 0; i < (n / 2); i++){
temp = str[i];
str[i] = str[n - i - 1];
str[n - i -1] = temp;
//C语言将A与B值互换,借助第三个变量
}
}
int main(){
char str[100];
gets(str);
// scanf("%s", str); //gets更简洁
Reverse(str);
printf("%s",str);
}
运行结果:
123.4
4.321
四、程序代码:(思路四)
#include<stdio.h>
int main(){
int n, a, b = 0;
scanf("%d", &n);
while(n > 0){ //提取每位数
a = n % 10;
n = n / 10;
b = b * 10 + a; //倒序递增
}
printf("%d", b);
return 0;
}
运行结果:
123
321
注意:
这里由于取余操作,故小数、字符串不可以。
总结:
上述,是总结的四种方法,利用了数组、函数、gets等 知识点,方法大同小异,旨在多方面解决问题,意见不同的可以评论留言 ,来提高能力。