20200910-3 命令行和控制台编程

此作业的要求参见  https://edu.cnblogs.com/campus/nenu/2020Fall/homework/11185

1.熟悉 命令行 和 控制台/标准输入和标准输出

 假设在当前目录下存在应用程序 a.exe 和 文件文件 b.txt,

请以数据流图并辅助以文字说明下述控制台命令的作用是什么。(5分)

a.exe < b.txt > c.txt

答:

  数据流图:

        

用:将b.txt中的数据输入到a.exe应用程序中,执行a.exe输出为c.txt。

请用C语言开发应用程序d.exe,从控制台指令读入命令行参数,并在控制台分别打印出a、b、c的值。运行效果形如下面的示例(6分)

代码:

#include <stdio.h>
int main(int argc, char* argv[])
{
  int a, b, c;
  sscanf(argv[1], "a=%d", &a);
  sscanf(argv[2], "b=%d", &b);
  sscanf(argv[3], "c=%d", &c);
  printf("%d\n\n", a);
  printf("%d\n\n", b);
  printf("%d\n\n", c);

  return 0;
}

执行效果图:

              

2.熟悉 测试用例

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

(2)在题目集 PAT (Basic Level) Practice (中文) 中任选3道题目完成。截图如下,要求包括1.红色对号、2.标号、3.用户名(此例中为 Young)。(30分)

 注意,需要读完本作业全部题目才能开始做题,有对时间记录和代码解读的要求。

(3)代码解读 (20分)

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

代码片断要求1 凡不缩进的,此题目拒绝接收。不知道什么是“缩进”的同学,请自行补课,不接受以“不知道”作为理由。

代码片断要求2 要求使用cnblogs代码控件,参见往届同学黄兴、宫成荣的作业。凡粘贴IDE中的代码截图,或者贴文字而没有关键字高亮或彩色的,0分。

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

卡拉兹(Callatz)猜想:

对任何一个正整数 n,如果它是偶数,那么把它砍掉一半;如果它是奇数,那么把 ( 砍掉一半。这样一直反复砍下去,最后一定在某一步得到 n=1。卡拉兹在 1950 年的世界数学家大会上公布了这个猜想,传说当时耶鲁大学师生齐动员,拼命想证明这个貌似很傻很天真的命题,结果闹得学生们无心学业,一心只证 (,以至于有人说这是一个阴谋,卡拉兹是在蓄意延缓美国数学界教学与科研的进展……

我们今天的题目不是证明卡拉兹猜想,而是对给定的任一不超过 1000 的正整数 n,简单地数一下,需要多少步(砍几下)才能得到 n=1?

代码:

#include<stdio.h>
int main()
{
    int n, i = 0;
    scanf("%d", &n);
    while (n != 1) {
        if (n % 2 == 0) {//判断奇偶
            n = n / 2;
        }
        else {
            n = (3 * n + 1) / 2;
        }
        i++;//统计步数
    }
    printf("%d", i);
    return 0;
}

执行效果图:

总结:这道题目相对简单,判断奇偶,统计步数,控制循环就可以。

 

1006 换个格式输出整数

让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12...n 来表示不为零的个位数字 n<10),换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。

代码:

#include <stdio.h>
int main(int argc, char* argv[])
{
    int n;
    int numB;
    int numS;
    int numT;
    int i = 0;
    char str[30];
    scanf("%d", &n);
    numB = n / 100;
    n = n % 100;
    numS = n / 10;
    n = n % 10;
    numT = n;
    for (i = 0; i < numB; i++)
        str[i] = 'B';
    for (; i < numB + numS; i++)
        str[i] = 'S';
    for (; i < numB + numS + numT; i++)
        str[i] = i - numB - numS + 1 + '0';//转成char
    str[i] = '\0';//结尾
    printf("%s\n", str);
    return 0;
}

执行效果图:

总结:这道题最后需要int类型转char类型,直接在+‘0’就可以实现。

1008 数组元素循环右移问题

一个数组A中存有N(>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(0)个位置,即将A中的数据由(A0​​A1​​AN1​​)变换为(ANM​​AN1​​A0​​A1​​ANM1​​)(最后M个数循环移至最前面的M个位置)。如果需要考虑程序移动数据的次数尽量少,要如何设计移动的方法?

代码:

#include<stdio.h>
int main()
{
    int N, M, i, j;
    int a[100];
    scanf("%d %d", &N, &M);
    for (i = 0; i < N; i++)
        scanf("%d", &a[i]);
        M = M % N; //当M大于N不用周期循环
    for (i = 0; i < M; i++)
    {
        int t;
        t = a[N - 1];
        for (j = N - 2; j >= 0; j--)
            a[j + 1] = a[j];//向后移一位
        a[0] = t;//最后一位等于第一位
    }
    printf("%d", a[0]);
    for (i = 1; i < N; i++)
        printf(" %d", a[i]);
    return 0;
}

执行效果图:

总结:这道题我减少了移动次数,当M>N的时候不需要做无意义的周期循环移动。

(4)控制台应用 (15分)

要求在博客中给出测试数据。

参照上一题中“控制台”的知识,给出运行时从控制台读入测试数据和向控制台输出的截图。

 

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

输入:3

输出:5

测试结果:

 

1006换个格式输出整数

输入:246

输出:BBSSSS123456

测试结果截图:

1008 数组元素循环右移问题

输入:6 2 

   1 2 3 4 5 6

输出:5 6 1 2 3 4

测试结果截图:

4) PSP(8分)

 

 

 

 

 

  

 

posted on 2020-09-13 23:01  wowzcy  阅读(190)  评论(2编辑  收藏  举报

导航