Liunx shell实现对用户输入两次数据的一致性检查

Shell 脚本实现接收用户两次输入的参数,并进行一系列校验,最终执行程序逻辑,可以按照以下步骤进行编写。具体功能包括:提示用户输入两个参数,去除空格、校验是否一致,确认继续,最后执行并输出结果。

Shell实现:

#!/bin/bash

# 函数:去除首尾空格
trim() {
    echo "$1" | sed 's/^[ \t]*//;s/[ \t]*$//'
}

# 函数:读取参数并校验一致性
get_input() {
    while true; do
        # 提示用户输入第一个参数
        read -p "请输入参数1: " param1
        param1=$(trim "$param1")  # 去除首尾空格

        # 判断第一个参数是否为空
        if [ -z "$param1" ]; then
            echo "参数1不能为空,请重新输入。"
            continue
        fi

        # 提示用户输入第二个参数
        read -p "请再次输入参数2以确认: " param2
        param2=$(trim "$param2")  # 去除首尾空格

        # 判断第二个参数是否为空
        if [ -z "$param2" ]; then
            echo "参数2不能为空,请重新输入。"
            continue
        fi

        # 判断两次输入是否一致
        if [ "$param1" != "$param2" ]; then
            echo "两次输入的参数不一致,请重新输入。"
        else
            break  # 输入一致,跳出循环
        fi
    done
}

# 函数:确认是否继续
confirm_continue() {
    read -p "参数一致,按回车键继续,或按 Ctrl+C 退出。" confirmation
}

# 主程序逻辑
main() {
    # 获取输入参数
    get_input

    # 确认继续
    confirm_continue

    # 假设执行一些程序逻辑,例如输出参数
    echo "执行逻辑,接收的参数为: $param1"

    # 这里可以替换为实际的逻辑,例如:
    # ./program-logic --param "$param1"
}

# 执行主程序
main

使用:

先赋予执行权限并运行脚本:

chmod +x input_check.sh
./input_check.sh

执行结果:

请输入参数1: abc123
请再次输入参数2以确认: abc
两次输入的参数不一致,请重新输入。
请输入参数1: abc123
请再次输入参数2以确认: abc123
参数一致,按回车键继续,或按 Ctrl+C 退出。
执行逻辑,接收的参数为: abc123
Linux shell脚本实现数独解题通常会涉及到一些字符串处理和逻辑判断。以下是一个简化的步骤概述: 1. **读取输入**:你可以通过`read`命令从标准输入获取用户输入的9x9的数独矩阵,每个数字一行。 2. **检查有效性**:验证输入是否合法,即每行、每列以及每个宫格(3x3小方块)内数字都应在1到9之间,且无重复。 3. **初始化变量和数据结构**:创建一个二维数组表示数独矩阵,可以使用哈希表或类似的数据结构来存储已填入的数字。 4. **递归算法**:可以采用回溯法(Backtracking)来解决数独问题。遍历每一个空格(0),尝试填入1到9的数字,然后递归地对每一行、每一列以及宫格进行检验。如果找到解决方案,则打印;若无法继续则回退并尝试下一个数字。 5. **函数设计**:将上述过程封装成几个函数,如`check_row()`、`check_column()`和`check_box()`用于验证某个位置是否合适,`solve()`作为主解题函数。 6. **错误处理**:提供清晰的错误提示,当遇到无效的数独输入或者无法找到解决方案时,停止程序并告知用户。 下面是一个非常基础的伪代码示例: ```bash # 函数定义 function check_position() { #... } function solve() { for cell in "${Sudoku[@]}"; do if [[ $cell -eq 0 ]]; then for num in {1..9}; do Sudoku[cell]="$num" if check_position "$cell" && solve; then echo "Solution found:" print_sudoku return fi Sudoku[cell]="0" done return 1 # 如果所有尝试都失败,返回错误 fi done echo "Solution exists!" print_sudoku } # 主体部分 while IFS= read -r line; do IFS=' ' read -ra row <<< "$line" Sudoku=("${row[@]}" "${Sudoku[@]}") done # 检查输入的有效性 if ! check_input "$Sudoku"; then echo "Invalid Sudoku puzzle." else solve fi ``` 请注意,这只是一个基本框架,实际实现会更复杂,因为要考虑到所有边界条件和细节。而且,这个例子没有包含所有的辅助函数和具体的错误处理,你需要根据实际情况去完善它。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值