#include"stdio.h"
#include"stdlib.h"
#include"time.h"
int main()
{
srand((unsigned int)time(0));
int count=0;
int num[20];
for(int i=0;i<=19;i++)
{
num[i]=rand()%1001;
printf("%d ",num[i]);
count++;
if(count==5)
{
printf("\n");
count=0;
}
}
printf("\n");
int num_20;
num_20=num[19];
for(int i=18;i>=0;i--)
{
num[i+1]=num[i];
}
num[0]=num_20;
puts("移动后数组的数据: ");
count=0;
for(int i=0;i<20;i++)
{
printf("%d ",num[i]);
count++;
if(count==5)
{
count=0;
printf("\n");
}
}
printf("\n");
int temp;
for(int i=1;i<=19;i++)
{
for(int j=1;j<=20-i;j++)
{
if(num[j-1]>num[j])
{
temp=num[j];
num[j]=num[j-1];
num[j-1]=temp;
}
}
}
count=0;
puts("数组从小到大排列:");
for(int i=0;i<=19;i++)
{
printf("%d ",num[i]);
count++;
if(count==5)
{
count=0;
printf("\n");
}
}
printf("\n");
int max_num,min_num,max_pos,min_pos;
max_num=min_num=num[0];
max_pos=min_pos=0;
for(int i=1;i<=19;i++)
{
if(max_num<num[i])
{
max_num=num[i];
max_pos=i;
}
if(min_num>num[i])
{
min_num=num[i];
min_pos=i;
}
}
printf("最大的数是:%d ",max_num);
printf("它在数组中的位置是:%d\n",max_pos+1);
printf("最小的数是:%d ",min_num);
printf("它在数组中的位置是:%d\n\n",min_pos+1);
return 0;
}
//注意,一定是先用一个新的变量保存好第20个数据,然后将数组中1~19个数据从第19个数据开始依次后移,最后将第20个数据保存到第1个位置。(如果用一个新的变量保存好第20个数据之后,就直接将第20个数据保存到第一个位置,那么数据就会先占了第一个位置,第一个位置原来的数也就不存在了,下面向后移的过程中,第一个数就变成了最后一个数,因此,它又一次被输出,从而与预期效果不一样。)
//:要有全局观念,因为整个数组在是有排列的,所以在整个程序中,都要保持i的初始值和终值,所以若随便改动一个i的初始值为1,那么数组原本的第一个数就会输出0。同理,若随便使一个终值减少1,那么可能最后一个数可能会不输出,或者少一个数而使换了位置之后有一个数的输出为0。
i和j只是个代表,数组中写那个无所谓。
count=0不能写在for语句中,否则每次都循环为0,永远不可能为5,没意义了。