码云地址:https://gitee.com/shikexin/16012018_shi_ke_xin

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 Main{
  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条件分支语句,数组

7-2 字符串逆序 (15 分)

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

输入格式:

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

输出格式:

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

输入样例:

Hello World!

输出样例:

!dlroW olleH

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

结果:

 

程序设计思路:输入一个字符串,将输入的字符串逆序输出

知识点:stringbuffer类创建对象使用reverse().toString()方法

 

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

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

输入格式:

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

输出格式:

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

输入样例:

4
5 1 7 6

输出样例:

7 6 5 1

import java.util.Scanner;
public class Main2{
  public static void main(String args[]){
    Scanner can = new Scanner(System.in);
      int n = can.nextInt();
      int[] a = new int[n];
      int x=0;
      for(int i=0;i<n;i++){
        a[i]=can.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(" ");
        }
      }
  }
}

结果:

设计思路:每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,交换位置

知识点:for循环,数组 ,选择排序法

7-7 猜数字 (20 分)

一群人坐在一起,每人猜一个 100 以内的数,谁的数字最接近大家平均数的一半就赢。本题就要求你找出其中的赢家。

输入格式:

输入在第一行给出一个正整数N(104​​)。随后 N 行,每行给出一个玩家的名字(由不超过8个英文字母组成的字符串)和其猜的正整数(≤ 100)。

输出格式:

在一行中顺序输出:大家平均数的一半(只输出整数部分)、赢家的名字,其间以空格分隔。题目保证赢家是唯一的。

输入样例:

7
Bob 35
Amy 28
James 98
Alice 11
Jack 45
Smith 33
Chris 62

输出样例:

22 Amy
这个题不会


阶段性总结:

java学习了大半,已经学习了基本的数据类型与数组,运算符,表达式和语句,循环语句,if条件分支语句。学会了创建类和对象,子类和继承,接口与实现常见的实用类。相对于其他,对循环语句和条件语句还是可以,但对于接口和常用的实用类,子类和继承能看懂程序,但还不能做题准确地写出,没有熟练的应用,在解决问题的方法上想的不全面,看见难的题就会卡住了,没有很好的思路

 
学习内容 代码行数 博客数
java数组 100 90
java方法 46 70