个人根据出租问题对字符数组的输入处理及按需输出的相应分析

日期:2023-12-2

一:出租问题:


本题要求你编写一个程序,为任何一个电话号码生成这段代码 
arr数组中的数字为电话号码出现的数字,每个数字只提取一次,且必须按递减顺序给出。

index数组就是arr数组的下标

index[0]=2 对应 arr[2]=1,index[1]=0 对应 arr[0]=8,index[2]=3 对应 arr[3]=0,

//18013820100
//int[] arr = new int[] {8, 3, 2, 1, 0};
//int[] index = new int[] {3, 0, 4, 3, 1, 0, 2, 4, 3, 4, 4};

二:个人对于解决多组数组处理数据时的想法

(1)因为涉及到对于电话号码数字的提取和加密操作,要求对于输入的一系列数字进行处理,所以需要调用字符串数组b对于每个数字进行字符录入,这样才能满足后续对于11位数字的逐位加密操作并录入数组index。这一步建议使用while循环,并以输入回车作为循环的结束,倘若使用for循环,则需要特别对于第12位数字时进行标记结束。下方程序使用的是VS2022编译器,所以自动实现了对于字符串数组结束符---空字符的录入。

(2)新定义空字符串数组a,并将其中空字符同字符数组b进行比较,施加内外循环,内循环控制数组a,外循环控制数组b,对于每个数组b当中的元素,用遍历a当中的所有元素,去与数组b中的单一元素比较,如果数组a中不存在与之相同的元素,则设计标记,并在内外循环间进行录入,录入的同时,通过计数器原理,来计算数组a中元素的个数,方便后续对于数组a中的元素下标进行提取并加密手机号码

(3)对于数组a中元素,设计内外循环实现顺序排序(降序排序),以此来满足题目需求,程序设计到这一步,就已经完成了对于arr数组的处理

(4)在已经配置计数器的情况下,拥有对于数组arr(即数组a)的处理结果,此时只需要设计循环判断语句,对于数组b和数组a中相同的元素,调用数组c实现对于数组a下标的录入

(5)依据数组ar(数组a)和数组index(数组c)的输出要求,去配置对应符合题目检测点的打印语句,并可以通过设定判断程序,来满足特殊的打印需求。

三:代码注释及运行情况

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
    char a[11] = {11};
    char b[10000];
    char m;
    int c[11];
    int i=0 ,j;
    int k;
    int n,cnt=0;
    int flag = 0;
    int temp, t,index;
    while ( (m= getchar()) != '\n')//超出数组范围和不是规定数据类型都会使程序崩溃
    {
        b[i] = m;
        i++;
    }
    //检验点一:检验字符数组b的输入
    // 
    //for (k = 0; k < 11; k++)
    //{
    //    printf("%c", b[k]);
    //}
    //printf("\n");


    考虑到第二个数组的选择依据是全部电话号码,如果使用for循环则是输入单一11位数数字
    for (i = 0; i < 11; i++)
    {
        for (j = 0; j < 11;j++)
        {
            if (b[i] == a[j])
            {
                flag = 1;
            }
        }
        if (flag == 0)
        {
            a[cnt] = b[i];//实现数组元素对于数组元素覆盖
            cnt++;//记录最小数字下标,本题是要求arr数组降序排列
        }
        flag = 0;//计数器原理实现,需要在循环的末位进行清空
    }

    //检验点二:检验计数器的大小
    // 
    //printf("%d\n\n", cnt);
    for (j = 0; j < cnt-1; j++)
    {
        t = j;
        for (i = j + 1; i < cnt; i++)
        {
            if (a[i] > a[t])
            {
                t = i;
            }
        }
        temp = a[t];
        a[t] = a[j];
        a[j] = temp;
    }
//    //完成第一项指标,实现数组的降序排列选择调用手机号数组,同简化号码数组进行比较,再通过下标实现对于数组c的加密生成
    //检验点三:检验数组a的降序排列并判断是否筛除重复元素
    // 
    //for (i = 0; i < cnt; i++)
    //{
    //    printf("%c\n", a[i]);
    //}

    //数组a已经完成降序排列,并已经除去了重复元素

    //第二项指标针对数组b进行,取单一元素进行匹配
    //因为要求去数组a中元素进行对比,提取其下标并生成数组c

    for (i = 0; i < 11; i++)
    {
        for (j = 0; j < cnt; j++)//break语句生成
        {
            if (b[i] == a[j])
            {
                c[i] = j;
            }
        }
    }
    //数组c完成了对于数组a中对应数字的下标提取
    // 检验点四:检验数组c是否完成了对于数组a的下标数字的提取及加密
    //for (i = 0; i < 11; i++)
    //{
    //    printf("%d\n", c[i]);
    //}
    printf("int[] arr = new int[] {");
        for (i = 0; i < cnt; i++)
        {
            if (i == 0)
            {
                printf("%c",a[i]);
            }
            else
            {
                printf(", %c", a[i]);
            }
        }
        printf("};\n");
        printf("int[] index = new int [] {");
        for (i = 0; i < 11; i++)
        {
            if (i == 0)
            {
                printf("%d", c[i]);
            }
            else
            {
                printf(", %d", c[i]);
            }
        }
        printf("};\n");
    return 0;
}

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值