一阶段-FifteenthWork-2-使用ArrayList

本文通过一个具体例子展示了如何使用 Java 中的 ArrayList 来存储客户邮件地址的相关信息,并将这些信息进行展示。示例代码中创建了一个名为 ReToString 的类来封装地址细节,并利用 ArrayList 对象来收集和展示这些数据。
/*
2. 编写一个程序,使用ArrayList存储客户的邮件地址。地址中应该包含姓名、街道、市(县)、省(自治区)、国家(地区)和代码,
然后显示ArrayList中的内容,
*/
package FifteenthWork;

import java.util.ArrayList;

class ReToString
{
    private String name;
    private String street;
    private String city;
    private String country;
    private String pinCode;

    public ReToString(String name, String street, String city, String country, String pinCode) {
        this.name = name;
        this.street = street;
        this.city = city;
        this.country = country;
        this.pinCode = pinCode;
    }
    @Override
    public String toString()
    {
        return "\nname:"+name+"\nstreet:"+street+"\ncity:"+city+"\ncountry:"+country+"\npinCode:"+pinCode+"\n";
    }
}
public class SecondArray
{
    public static void main(String[] args)
    {
        ReToString str1 = new ReToString("David Clarke","10 Downing Street","LondonState:London",
        "United Kindom","110022");
        ReToString str2 = new ReToString("John Lenon","12 Park Avenue","CaliforniaState:California",
        "USA ","210033");
        ReToString str3 = new ReToString("Stefii Graff","14 Maple lane","Sydney",
        "Australia","412033");
        ArrayList arr = new ArrayList();
        arr.add(str1);
        arr.add(str2);
        arr.add(str3);                 
        System.out.println(arr); 
    }
}
下载代码方式:https://pan.quark.cn/s/a4b39357ea24 依据所提供的资料,我们深入剖析此问题以及所给出的两种算法方案。 ### 问题背景 该问题源自王晓东编撰的《算法设计与实验题解》书,书中阐述了个值得注意的数学议题:针对本页码从1到n顺序编号的书籍,要求统计所有页码中数字0至9各自出现的频次。例如,若n=13,则页码序列为1、2、...、13,其中数字1出现5次(体现在1、10、11、12、13中),数字0出现1次(体现在10中)。 ### 问题描述 具体而言,我们需要开发种算法,其输入参数为个正整数n,输出结果需为0至9这十个数字各自出现的频次。所有页码均以十进制形式呈现,且不包含任何前导零,即不会出现如006之类的页码表示。 ### 解决方案:时间复杂度为O(n*log10(n))的算法 首先,介绍种时间复杂度为O(n*log10(n))的算法实现。其核心构思在于遍历从1到n的每个数值,然后逐分解每个数值的各个位,并统计各类数字出现的频次。具体步骤如下: 1. 初始化个长度为10的数组`count`,用于记录0至9每个数字出现的频次,初始值均为0。 2. 从1开始遍历至n,对于每个数值i,将其转换为整数并进行以下操作: - 利用循环结构,持续将当前数值除以10,获取余数(即当前最低位的数字),并累加到对的计数器中。 3. 遍历完成后,输出`count`数组中的每个元素,即为所求的结果。 ### 解决方案二:优化算法 为了提升效率,提出了种更为优越的算法。该算法基于以下观察:在1到10^n-1之间的任意区间内,每种数字0至9出现的频次是相等的。例如,在1到999之间,每种数字0至9出现的频次均相...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值