「PAT乙级真题解析」Basic Level 1084 外观数列 (问题分析+完整步骤+伪代码描述+提交通过代码)
admin
2024-03-28 04:58:10
0

乙级的题目训练主要用来熟悉编程语言的语法和形成良好的编码习惯和编码规范。从小白开始逐步掌握用编程解决问题。

PAT (Basic Level) Practice 1084 外观数列

问题分析

  • 题设定义外观数列就是第n项是对第n-1项各个数字连续出现次数的统计, 跟"1078 字符串压缩与解压"类似。
  • 比如:
    • “2"的下一项是描述"2"出现了1次, 所以是"21”
    • “21"的下一项是"2"出现了1次, 1出现了1次, 所以是"2111”
    • “2111"的下一项是"2"出现了1次, 1出现了3次, 所以是"2113”

完整描述步骤

  1. 获取输入: 起始数字, 目标项的序号
  2. 如果要求输出的是第1项:
    • 直接输出起始数字
    • 结束程序
  3. 初始化记录器:
    • 上一项 = 起始数字
    • 当前项 = 空字符串
    • 上一个字符 = “@”
    • 上一个字符已经出现的次数 = 0
  4. 循环(target_order - 1)次:
    • 对于上一项的中每一个字符:
      • 如果是第一个字符:
        • 设置 上一个字符 = 当前字符
        • 设置 上一个字符已经出现的次数 = 1
        • continue
      • 如果当前字符不等于上一个字符:
        • 当前项 += “{上一个字符}{上一个字符已经出现的次数}”
        • 设置 上一个字符 = 当前字符
        • 设置 上一个字符已经出现的次数 = 1
      • 否则:
        • 上一个字符已经出现的次数++
  5. 输出当前项

伪代码分析

  1. get input: digit, target_order
  2. if target_order == 1:
    • print(digit);
    • end procedure;
  3. init recorder:
    • last_item = string(digit)
    • current_item = “”
    • last_digit = “@”
    • frequency = 0
  4. for i in range(1, target_order):
    for idx, char in last_item:
    - if idx == 0:
    - last_digit = char;
    - frequency = 1;
    - continue;
    - if char != last_digit:
    - current_item += “{last_digit}{frequency}”
    - last_digit = char;
    - frequency = 1;
    - else:
    - frequency++;
  5. print(current_item);

注意事项

  1. 数组如果不够长, 测试点4可能发生段错误。需要将长度设置为100000.

完整提交代码

/*
# 问题分析
题设定义外观数列就是第n项是对第n-1项各个数字连续出现次数的统计, 跟"1078 字符串压缩与解压"类似。
比如: 
- "2"的下一项是描述"2"出现了1次, 所以是"21"
- "21"的下一项是"2"出现了1次, 1出现了1次, 所以是"2111"
- "2111"的下一项是"2"出现了1次, 1出现了3次, 所以是"2113"# 完整描述步骤
1. 获取输入: 起始数字, 目标项的序号
2. 如果要求输出的是第1项:- 直接输出起始数字- 结束程序
3. 初始化记录器:- 上一项 = 起始数字- 当前项 = 空字符串- 上一个字符 = "@"- 上一个字符已经出现的次数 = 0
4. 循环(target_order - 1)次:- 对于上一项的中每一个字符:- 如果是第一个字符:- 设置 上一个字符 = 当前字符- 设置 上一个字符已经出现的次数 = 1- continue- 如果当前字符不等于上一个字符:- 当前项 += "{上一个字符}{上一个字符已经出现的次数}"- 设置 上一个字符 = 当前字符- 设置 上一个字符已经出现的次数 = 1- 否则:- 上一个字符已经出现的次数++
5. 输出当前项# 伪代码分析
1. get input: digit, target_order
2. if target_order == 1:- print(digit);- end procedure;
3. init recorder:- last_item = string(digit)- current_item = ""- last_digit = "@"- frequency = 0
4. for i in range(1, target_order):for idx, char in last_item:- if idx == 0:- last_digit = char;- frequency = 1;- continue;- if char != last_digit:- current_item += "{last_digit}{frequency}"- last_digit = char;- frequency = 1;- else:- frequency++;
5. print(current_item);# 注意事项
1. 数组如果不够长, 测试点4可能发生段错误。需要将长度设置为100000.*/# include
# includeint main(){int digit, target_order;scanf("%d %d", &digit, &target_order);if (target_order == 1){printf("%d", digit);return 0;}char last_item[100000];char current_item[100000];memset(last_item, 0, 100000);memset(current_item, 0, 100000);last_item[0] = '0' + digit;int last_digit = '@';int frequency = 0;for (int i = 1; i < target_order; i++){int current_idx = 0;for (int j = 0; last_item[j]; j++){if (j == 0){last_digit = last_item[j];frequency = 1;continue;}if (last_item[j] != last_digit){current_item[current_idx] = last_digit;current_item[current_idx + 1] = '0' + frequency;current_idx += 2;last_digit = last_item[j];frequency = 1;} else {frequency++;}}current_item[current_idx] = last_digit;current_item[current_idx + 1] = '0' + frequency;strcpy(last_item, current_item);}printf("%s", current_item);return 0;
}

相关内容

热门资讯

人民日报钟声:自卫队加速“进攻... 历史观上的严重欠账,叠加走向扩张的战略图谋,使得日本自卫队对地区和平与稳定构成了严重威胁 近日,日本...
中方始终致力于维护全球产供链安... 在9日举行的例行新闻发布会上,商务部新闻发言人何亚东就稀土出口管制、中欧经贸关系以及电子商务发展等热...
伊朗外长与法国外长通话 呼吁欧... 当地时间9日,伊朗外交部长阿拉格齐与法国外长巴罗就中东地区局势等通话。 阿拉格齐在通话中指责美国和以...
点名德法西意等国,批评盟友“缺... 【环球时报驻法国特派记者 尚凯元 环球时报驻德国特约记者 青木 沈真】据《华尔街日报》8日报道,美国...
普京宣布停火32小时,泽连斯基... 来源:央视新闻 普京宣布停火32小时,乌方表示跟进 当地时间4月9日,据克里姆林宫消息,俄罗斯总统普...
日本自卫队为何要扩招女兵 专家... 日本媒体8日援引防卫省数据报道,因日本自卫队人手不足,为填补空缺,防卫省决定扩招女性队员,将女性占比...
协议已签、海峡未开:为何伊朗停... 智通财经获悉,尽管美国与伊朗之间的停火协议已于4月8日生效,但穿越霍尔木兹海峡——波斯湾地区石油、天...
原创 美... 美国专家惊呼:004航母将改写规则?福建舰已领先,美军优势还剩多少? 最近,美国那边有位懂行的老兄,...
蔚来李斌:明年预计会保持每个季... 9月2日消息,蔚来创始人、董事长、CEO李斌在2025年二季度财报电话会上表示,今年公司研发体系做了...
越南国家主席梁强抵达北京,将出... 9月2日消息,9月2日晚,越南国家主席梁强乘机抵达北京首都国际机场,将出席中国人民抗日战争暨世界反法...