作业要求 20190905-3 命令行和控制台编程

此作业的要求参见[https://edu.cnblogs.com/campus/nenu/2019fall/homework/5523]

 

1.熟悉 命令行和控制台

假设在当前目录下存在应用程序 a.exe 和 文件文件 b.txt,请以数据流图并辅助以文字说明下述控制台命令的作用是什么。

答:B里面的内容作为程序a的数据输入,最后结果结果输出到c并保存。

 

请用C言开发应用程序d.exe,从控制台指令读入命令行参数,并在控制台分别打印出a、b、c的值。

代码如下:

 

#include <stdio.h>
#include <stdlib.h>

int main()
{
    int a,b,c;
    scanf("a=%d b=%d c=%d",&a,&b,&c);
    printf("%d\n",a);
    printf("%d\n",b);
    printf("%d\n",c);
    return 0;
}

运行效果如下:

 2.熟悉 测试用例

(1)请在网站 [https://pintia.cn/]注册账号。

(2)在题目集 PAT (Basic Level) Practice (中文) 中任选3道题目完成。

截图如下:

(3)代码解读。

发表博客,介绍上述3个题目代码中重点/难点,展示重要代码片断,给出执行效果截图,展示你感觉得意、突破、困难的地方。

1001 害死人不偿命的(3n+1)猜想

重难点:这个题目属于比较简单的题目,就是判定一下数据是奇数还是偶数,判定后分别给予不同的处理罢了。

代码片段:

#include<stdio.h>
int main(){
    int n;
    int i=0;
    scanf("%d",&n);
    while(n!=1){
        if(n%2==0){
            n=n/2;
            i++;
        }
        else n=3*n+1;
    }
    printf("%d\n",i);
   
}

执行效果截图:

1002 写出这个数

重难点:我感觉这个题的重难点是如何把一个数各分位上的数加起来,我采用了将一个数按字符串输入,然后再转换成数字,用For循环将所有的数加起来,将0到9用拼音表示存在数组中,通过除法和除余来判断各个位上的数字然后再分别输出。

代码片段:

#include<stdio.h>
int main(){
    char n[100];
    int i=0;
    int j;
    scanf("%s",&n);
    for(;n[i]!='\0';i++)
    {
        j=j+(n[i]-'0');
    }
    char a[10][10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
    if(j>99)
    {
        printf("%s ",a[j/100]);
        printf("%s ",a[j%100/10]);
        printf("%s",a[j%100%10]);
    }
    else if(j>9)
    {
        printf("%s ",a[j/10]);
        printf("%s",a[j%10]);
    }
    else{
        printf("%s",a[j]);
    }
    return 0;
}

执行效果截图:

1003 我要通过

重难点:我认为这道题还是比较难的,首先这个读题就花费了很多的时间,第三个条件是最难判断的,前期一直不对,后来看了他给的测试用例,才猜测P前面A的个数乘以P和T之间的A的个数必须等于T后面的A的个数。

代码片段:

def func(lis):

    if 'A' in lis and 'P' in lis and 'T' in lis:

        if len(set(lis)) == 3 and lis.index('P') < lis.index('T'):
            start = lis.index('P')
            end = lis.index('T')
            numbefore = len(lis[:start])
            nummid = len(lis[start+1:end])
            numafter = len(lis[end+1:])

            if numbefore*nummid == numafter:
                return 1
            else:
                return 0
        return 0
    return 0


n = int(input())
ret = []
for i in range(n):
    ret.append(list(input()))
for lis in ret:
    if func(lis):
        print('YES')
    else:
        print('NO')

执行结果截图:

 

(4) PSP

 

在同一篇博客中,参照教材第35页表2-2和表2-3,为上述3个题目制作PSP阶段表格。

PSP阶段表格第1列分类,如功能1、功能2、测试功能1等。

总结出现时间差的原因

1 C语言的基本语法忘掉的太多,很多时候出现很低级的错误。

2 编写代码是逻辑混乱,对如何使用数组竟然产生了疑问,编写了一半又去查找关于数组方面的资料,导致编码时间过长。

3 对题目的解读能力太差,一直没有读懂第三个条件该如何写,测试了很多用例不通过,后来在给定的用例中发现规律,三个位置的A的数量是存在关系的,通过这种关系写的限制条件,这个题目我是用Python写的,因为我感觉用C语言实在是太麻烦了。

 

posted @ 2019-09-09 19:45  hejw031  阅读(171)  评论(0编辑  收藏  举报