day38 1477 拼写正确 (字符串处理、打表、模拟)

高效计算大数英文拼写:从12345到任意N的总和
本文介绍如何利用Java编程解决大数拼写问题,通过字符串处理实现N(0到10^100)的数字总和以英文形式输出,适合处理超出常规数据类型的题目。

1477. 拼写正确

给定一个非负整数 N,你的任务是计算 N 的所有数字的总和,并以英语输出总和的每个数字。

输入格式
共一行,包含一个整数 N。

输出格式
共一行,用英语输出总和的每个数字,单词之间用空格隔开。

数据范围
0≤N≤101000≤N≤10^{100}0N10100
输入样例:

12345

输出样例:

one five

思路:

直接模拟即可。

  1. 计算出各位上数字的总和。
  2. 由于需要从前往后遍历,故将总和转为字符串,用下标来找各位上的数字更方便。
  3. zero ~ nine十个英语单词先打表,之后直接查找并输出即可。

要注意的地方:

0≤N≤101000≤N≤10^{100}0N10100,故输入的N可能远远超出了intlong的范围,故我们第一反应就是用String来存这个数了。这也说明做算法题时,数据的输入范围有时也是解题的重要信息,有时甚至决定了代码的做法。

Java代码

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        //输入的数字可能很大(10^100),远远超出int和long的范围,所以我们直接用String存更好
        String strNum = sc.next();
        int sum = 0;
        //打表,方便后期查询
        String[] strs = {"zero","one","two","three","four","five","six","seven","eight","nine"};

        //得到数字strNum的各位上数字的总和
        for(int i = 0;i < strNum.length();i++){
            sum += strNum.charAt(i) - '0';
        }
       

        //将总和转为字符串,方便从头至尾遍历各个位上的数字
        String strSum = String.valueOf(sum);

        //可以转为英文输出了
        for(int i = 0;i < strSum.length();i++){
            System.out.print(strs[strSum.charAt(i) - '0'] + " ");
        }
    }
}

在这里插入图片描述

帮我检查哪里有问题:import sqlite3 import os from datetime import datetime, time, timedelta import random from database.db_manager import DatabaseManager from config import Config from processes.attendance_service import AttendanceService class TestDataGenerator: def __init__(self, db_path='test_attendance.db'): self.db_path = db_path self.conn = sqlite3.connect(db_path) self.conn.row_factory = sqlite3.Row self.db = db_path # 初始化考勤服务 self.attendance_service = AttendanceService(db_path) def create_table(self): """创建打卡记录表""" c = self.conn.cursor() c.execute('''CREATE TABLE IF NOT EXISTS records ( id INTEGER PRIMARY KEY AUTOINCREMENT, badge_id TEXT NOT NULL, name TEXT NOT NULL, timestamp REAL NOT NULL, department TEXT, face_path TEXT, status TEXT DEFAULT 'normal', check_in_type TEXT DEFAULT '上班', actual_work_hours REAL, expected_work_hours REAL )''') self.conn.commit() print("数据表创建成功") def generate_test_data_with_smart_check(self): """使用您的smart_check函数生成测试数据""" db_manager = DatabaseManager() # 三个测试人员 test_employees = [ # 完全匹配的案例 {'badge_id': '18080698', 'name': '卢xx', 'department': '消费产品研发部'}, {'badge_id': '18091664', 'name': '吴xx', 'department': '消费产品研发部'}, {'badge_id': '18083304', 'name': '容xx', 'department': '消费产品研发部'}, {'badge_id': '18092651', 'name': '冼xx ', 'department': '消费产品研发部'} ] # 生成近30天的数据 base_date = datetime.now() for day in range(30, 0, -1): current_date = base_date - timedelta(days=day) print(f"\n=== 生成 {current_date.strftime('%Y-%m-%d')} 的数据 ===") for emp in test_employees: # 上班打卡时间 (8:00-9:30之间) check_in_time = current_date.replace( hour=random.randint(8, 9), minute=random.randint(0, 59), second=random.randint(0, 59), microsecond=0 ) # 下班打卡时间 (17:00-19:00之间) check_out_time = current_date.replace( hour=random.randint(17, 19), minute=random.randint(0, 59), second=random.randint(0, 59), microsecond=0 ) # # 随机生成一些异常状态(15%的概率) # status_override = None # if random.random() < 0.15: # status_override = random.choice(['late', 'leave_early']) print(f"\n处理 {emp['name']}({emp['badge_id']}):") # 模拟上班打卡 print(f" 上班打卡: {check_in_time.strftime('%H:%M:%S')}") result1 = self.attendance_service.smart_check( self, emp['badge_id'], emp['name'], face_path=None, department=emp['department'] ) if result1: print(f" ✅ 上班打卡成功") else: print(f" ⚠️ 上班打卡跳过") # 等待一段时间(模拟实际间隔) #time_module.sleep(0.1) # 模拟下班打卡 print(f" 下班打卡: {check_out_time.strftime('%H:%M:%S')}") result2 = self.attendance_service.smart_check( self, emp['badge_id'], emp['name'], face_path=None, department=emp['department'] ) if result2: print(f" ✅ 下班打卡成功") else: print(f" ⚠️ 下班打卡跳过") print("\n✅ 测试数据生成完成!") # 使用示例 if __name__ == "__main__": # 创建测试数据生成器 generator = TestDataGenerator('badge_records.db') try: # 创建数据表 generator.create_table() # 生成基础测试数据 generator.generate_test_data_with_smart_check() # 显示样本数据 #generator.show_sample_data() print("\n✅ 测试数据库生成完成!") print(f"数据库文件: {generator.db_path}") finally: generator.close()
最新发布
08-26
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值