编写函数实现在按降序排列的成绩数组中,插入一个新的学生成绩后,该成绩数组仍然按降序排列

如题所述

packagecom.cn.u4;

importjava.util.Scanner;

@authorAdministrator;向有序数组中插入学员成绩;在一组降序排列的数据中插入一个数据,插入后,数组中数据依然按降序排列

publicclassInsertNum{

publicstaticvoidmain(String[]args){

//要确保插入数据有位置,必须数组长度多一位,所以定义数组的时候,要这样定义

int[]nums=newint[6];

nums[0]=789;

nums[1]=100;

nums[2]=89;

nums[3]=78;

nums[4]=65;

//让用户输入插入数据

Scannerinput=newScanner(System.in);

System.out.print("请输入数据:");

intwant=input.nextInt();

//拿用户输入的数据和原来数组中的数据去比较

//找到要插入的位置,下标,第一次比别人大

intindex=-1;//下标初始值,可以随意,它在后面也还是会被赋值的,所以这里只是为了不报错给个初始值,除数组下标0.。。。。5以外,都可以

for(inti=0;i<nums.length;i++){

if(want>nums[i]){

index=i;

break;//只要查找到第一次找到比输入值小的,就可以了,所以用break来结束for循环

System.out.println("要移动到的下标是:"+index);

//插入数据,其后数据依次向右移一位,这里要分析一下,

//因为上面定义的num[5]也就是第6个位置没有被使用,是空的,那么我们要把num[4]移动到num[5]上来,依此类推,在index位置处后面的依次都要向右移一位

for(inti=nums.length-1;i>0;i--){

if(index==i){//只移从插入那个坐标开始以及后面的数据

break;

nums[i]=nums[i-1];//把前一位赋值给后一位

nums[index]=want;//把输入的值赋给index坐标的位置

//使用增强型循环数组

for(intnum:nums){

System.out.print(num+"\t");

//输出数组

扩展资料:

system()用法

windows操作系统下system()函数详解(主要是在C语言中的应用)

功能:发出一个DOS命令

用法:intsystem(char*command);

system函数已经被收录在标准c库中,可以直接调用。

程序例:

#include<stdlib.h>

#include<stdio.h>

intmain(void)

printf("AbouttospawnandrunaDOScommand\n");

system("dir");

return0;

又如:system("pause")可以实现冻结屏幕,便于观察程序的执行结果;system("CLS")可以实现清屏操作。而调用color函数可以改变控制台的前景色和背景,具体参数在下面说明。

例如,用system("color0A");其中color后面的0是背景色代号,A是前景色代号。各颜色代码如下:

0=黑色1=蓝色2=绿色3=湖蓝色4=红色5=紫色6=黄色7=白色8=灰色9=淡蓝色A=淡绿色B=淡浅绿色C=淡红色D=淡紫色E=淡黄色F=亮白色。

温馨提示:答案为网友推荐,仅供参考
第1个回答  2018-04-15
在表格或数值数组 (数组:用于建立可生成多个结果或可对在行和列中排列的一组参数进行运算的单个公式。数组区域共用一个公式;数组常量是用作参数的一组常量。)的首行查找指定的数值,并由此返回表格或数组当前列中指定行处的数值。当比较值位于数据表的首行,并且要查找下面给定行中的数据时,请使用函数 HLOOKUP。当比较值位于要查找的数据左边的一列时,请使用函数 VLOOKUP。 公式 说明(结果) =HLOOKUP("Axles",A1:C4,2,TRUE) 在首行查找 Axles,并返回同列中第 2 行的值。 =HLOOKUP("Bearings",A1:C4,3,FALSE) 在首行查找 Bearings,并返回同列中第 3 行的值。 =HLOOKUP("B",A1:C4,3,TRUE) 在首行查找 B,并返回同列中第 3 行的值。由于 B 不是精确匹配,因此将使用小于 B 的最大值 Axles。 =HLOOKUP("Bolts",A1:C4,4) 在首行查找 Bolts,并返回同列中第 4 行的值。 =HLOOKUP(3,{1,2,3;"a","b","c";"d","e","f"},2,TRUE) 在数组常量的第一行中查找 3,并返回同列中第 2 行的值。本回答被网友采纳