1.源代码
#include <stdio.h>
int main(){
int a[100],n,i,tmp;
scanf("%d",&n);
for(i=0;i<n;i++)
a[i]=2*i+1;
for(i=0;i<n;i++)
printf("%3d",a[i]);
printf("\n");
for(i=0;i<n/2;i++){
tmp=a[i];
a[i]=a[(n-1)-i];
a[(n-1)-i]=tmp;
}
for(i=0;i<n;i++)
printf("%3d",a[i]);
return 0;
}
2.代码思路
- 定义一个主函数
main
,它首先声明一个长度为100的整数数组a
,一个整数变量n
,一个循环控制变量i
,和一个临时变量tmp
。然后,使用scanf
函数从标准输入读取一个整数n
,表示数组的实际长度。 - 接下来,使用一个
for
循环,生成一个长度为n
的奇数数组,即a[i]=2*i+1
,其中i
从0到n-1
变化。这样,数组a
的元素依次是1, 3, 5, ..., 2*n-1
。 - 然后,使用一个
for
循环,遍历数组a
的所有元素,并使用printf
函数将它们以3个字符的宽度输出到标准输出。输出的数组是[1, 3, 5, ..., 2*n-1]
。 - 再然后,使用
printf
函数输出一个换行符,以分隔两个数组的输出。 - 接着,使用一个
for
循环,将数组a
反转,即将数组的首尾两个元素交换,然后依次向中间移动,直到交换完n/2
对元素。交换的方法是使用一个临时变量tmp
来存储其中一个元素的值,然后互换另一个元素的值。例如,如果n
是4,那么数组a
的元素是[1, 3, 5, 7]
,交换后的元素是[7, 5, 3, 1]
。 - 最后,使用一个
for
循环,遍历数组a
的所有元素,并使用printf
函数将它们以3个字符的宽度输出到标准输出。输出的数组是[2*n-1, 2*n-3, ..., 3, 1]
。