第三次过程性考核

码云仓库:https://gitee.com/wcnma/codes/c1mb0wtxsndu2e6g5kolr40

7-1 输出数组元素 (15 分)

本题要求编写程序,对顺序读入的n个整数,顺次计算后项减前项之差,并按每行三个元素的格式输出结果。

输入格式:

输入的第一行给出正整数n个整数,其间以空格分隔。

输出格式:

顺次计算后项减前项之差,并按每行三个元素的格式输出结果。数字间空一格,行末不得有多余空格。

输入样例:

10
5 1 7 14 6 36 4 28 50 100

输出样例:

-4 6 7
-8 30 -32
24 22 50

import java.util.Scanner;
public class Main1{
  public static void main(String args[]){
        Scanner reader = new Scanner(System.in);
        int n = reader.nextInt();
        int[] a = new int[n];
        int i=0;
        int cnt=0;
        for(i=0;i<n;i++){
          a[i]=reader.nextInt();
        }
        for (i = 0; i < n - 1; i++){
            a[i] = a[i + 1] - a[i];
        }
        for (i = 0; i < n - 1; i++){
            if (i == 0){
                System.out.printf("%d", a[0]);
            }
            else if (cnt == 3){
                System.out.printf("\n");
                System.out.printf("%d", a[i]);
                cnt = 0;
            }
            else{
                System.out.printf(" %d", a[i]);
            }
            cnt++;
        }
      }
    }

设计思路:顺次输入n个整数,利用for循环算出后项减去前项之差

知识点:for循环结构,if-else条件分支语句,数组

结果:

10
5 1 7 14 6 36 4 28 50 100

-4 6 7
-8 30 -32
24 22 50
7-2 字符串逆序 (15 分)

输入一个字符串,对该字符串进行逆序,输出逆序后的字符串。

输入格式:

输入在一行中给出一个不超过80个字符长度的、以回车结束的非空字符串。

输出格式:

在一行中输出逆序后的字符串。

输入样例:

Hello World!

输出样例:

!dlroW olleH

import java.util.Scanner;
public class chuan{
  public static void main(String args[]){
    Scanner sca = new Scanner(System.in);
    String str = sca.nextLine();
    StringBuffer sb = new StringBuffer(str);
    System.out.print(sb.reverse().toString());
  }
}

程序思路:定义一个数组,用StringBuffer对象使用reverse()方法将StringBuffer对象实体中的字符串进行逆序输出

运用知识点:采用StringBuffer对象、reverse()方法

结果:Hello World!

           !dlroW olleH

7-3 选择法排序 (20 分)

本题要求将给定的n个整数从大到小排序后输出。

输入格式:

输入第一行给出一个不超过10的正整数n个整数,其间以空格分隔。

输出格式:

在一行中输出从大到小有序的数列,相邻数字间有一个空格,行末不得有多余空格。

输入样例:

4
5 1 7 6

输出样例:

7 6 5 1

import java.util.Scanner;
public class xuanze{
  public static void main(String args[]){
    Scanner reader = new Scanner(System.in);
      int n = reader.nextInt();
      int[] a = new int[n];
      int x=0;
      for(int i=0;i<n;i++){
        a[i]=reader.nextInt();
      }
      for(int i=0;i<n;i++){
        for(int j=1;j<n;j++){
          if(a[j]>a[j-1]){
            x=a[j];
            a[j]=a[j-1];
            a[j-1]=x;
          }
        }
      }
      for(int i=0;i<n;i++){
        System.out.print(a[i]);
        if(i!=n-1){
          System.out.print(" ");
        }
      }
  }
}

程序思路:输入一个数为数组长度,遍历元素找到一个最大的元素,把它放在第一个位置每一个需要与下一个进行对比,因此需要运行n-1次循环

运用知识点:数的替换定义和数组、for循环

结果:

4
5 1 7 6

7 6 5 1

转载于:https://www.cnblogs.com/826498tang/p/9903647.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值