zoukankan      html  css  js  c++  java
  • 软件工程第三周课上练习

      1 package 数组;
      2 
      3 import java.io.BufferedReader;
      4 import java.io.File;
      5 import java.io.FileInputStream;
      6 import java.io.FileWriter;
      7 import java.io.IOException;
      8 import java.io.InputStreamReader;
      9 import java.util.ArrayList;
     10 import java.util.List;
     11 import java.util.Scanner;
     12 
     13 public class Shuzu7 {
     14 public static void main(String[] args)throws IOException
     15 {
     16 List<Integer> list=new ArrayList<>();
     17 Scanner scan=new Scanner(System.in);
     18 System.out.println("请执行操作:1、普通数组求最大子数组       2、百万数组求最大子数组");
     19 int x=scan.nextInt();
     20 if(x==1)
     21 {
     22  try {
     23     File file = new File("shuzu.txt");
     24     if(file.isFile() && file.exists()) {
     25       InputStreamReader isr = new InputStreamReader(new FileInputStream(file), "utf-8");
     26       BufferedReader br = new BufferedReader(isr);
     27       String lineTxt = "";
     28       while ((lineTxt = br.readLine()) != null){
     29        list.add(Integer.parseInt(lineTxt));
     30       }
     31       Object[]a=list.toArray();
     32       System.out.println((int)a[1]+(int)a[3]);
     33       br.close();
     34  int sum=a.length;
     35  int sum1=0;
     36 for(int i=1;i<=sum;i++)
     37 {
     38 sum1=sum1+i;
     39 }
     40 int [] b=new int[sum1];
     41 int temp1=0;
     42 for(int i=0;i<sum;i++)
     43 {
     44 int temp=0;
     45 for(int k=0;k<sum-i;k++)
     46 {   
     47     temp=temp+(int)a[i+k];
     48 b[temp1]=temp;
     49 temp1++;
     50 }
     51 }
     52 for(int i=0;i<sum1-1;i++)
     53 for(int k=0;k<sum1-1-i;k++)
     54 {
     55 if(b[k]<b[k+1])
     56 {
     57 int temp2=b[k];
     58 b[k]=b[k+1];
     59 b[k+1]=temp2;
     60 }
     61 }
     62 System.out.println("最大的子数组和为"+b[0]);
     63     } else {
     64       System.out.println("文件不存在!");
     65     }
     66   } catch (Exception e) {
     67     System.out.println("文件读取错误!");
     68   }
     69 }
     70 if(x==2)
     71 {
     72 FileWriter fw = null;
     73   try {
     74             //创建字符输出流
     75             fw = new FileWriter("shuzu1.txt");
     76             for(int i=0;i<50;i++)
     77             {
     78                 int intval=(int)(Math.random()*-9000000+8999999);
     79             fw.write(""+intval+"
    ");
     80             }
     81         } catch (IOException ioe) {
     82             ioe.printStackTrace();
     83         } finally {
     84             //使用finally块来关闭文件输出流
     85             if (fw != null) {
     86                 fw.close();
     87             }
     88         }
     89   try {
     90     File file = new File("shuzu1.txt");
     91     if(file.isFile() && file.exists()) {
     92       InputStreamReader isr = new InputStreamReader(new FileInputStream(file), "utf-8");
     93       BufferedReader br = new BufferedReader(isr);
     94       String lineTxt = "";
     95       while ((lineTxt = br.readLine()) != null){
     96        list.add(Integer.parseInt(lineTxt));
     97       }
     98       Object[]a=list.toArray();
     99       System.out.println((int)a[1]+(int)a[3]);
    100       br.close();
    101  int sum=a.length;
    102  int sum1=0;
    103 for(int i=1;i<=sum;i++)
    104 {
    105 sum1=sum1+i;
    106 }
    107 int [] b=new int[sum1];
    108 int temp1=0;
    109 for(int i=0;i<sum;i++)
    110 {
    111 int temp=0;
    112 for(int k=0;k<sum-i;k++)
    113 {   
    114     temp=temp+(int)a[i+k];
    115 b[temp1]=temp;
    116 temp1++;
    117 }
    118 }
    119 for(int i=0;i<sum1-1;i++)
    120 for(int k=0;k<sum1-1-i;k++)
    121 {
    122 if(b[k]<b[k+1])
    123 {
    124 int temp2=b[k];
    125 b[k]=b[k+1];
    126 b[k+1]=temp2;
    127 }
    128 }
    129 System.out.println("最大的子数组和为"+b[0]);
    130     } else {
    131       System.out.println("文件不存在!");
    132     }
    133   } catch (Exception e) {
    134     System.out.println("文件读取错误!");
    135   }
    136 }
    137   }
    138 
    139 }
  • 相关阅读:
    Oracle查询当前用户和当前用户下的所有表
    poj 1222EXTENDED LIGHTS OUT
    poj 1753 Flip Game
    老李分享:loadrunner用javavuser进行接口测试
    性能测试培训:帮你定位 Linux 性能问题的 18 个命令以及工具
    cf158B(水题)
    AC自动机讲解+[HDU2222]:Keywords Search(AC自动机)
    [BZOJ2120]:数颜色(分块?)
    赋值运算,拷贝运算,运算符重载
    Fraction to Recurring Decimal(STRING-TYPE CONVERTION)
  • 原文地址:https://www.cnblogs.com/0518liu/p/10615337.html
Copyright © 2011-2022 走看看