C++课程设计实验杭州电子科技大学ACM题目(中)

简介: C++课程设计实验杭州电子科技大学ACM题目(中)

题目四:2016.数据的交换输出

题目描述

Problem Description:

输入n(n<100)个数,找出其中最小的数,将它与最前面的数交换后输出这些数。

Input:输入数据有多组,每组占一行,每行的开始是一个整数n,表示这个测试实例的数值的个数,跟着就是n个整数。n=0表示输入的结束,不做处理。

Output:对于每组输入数据,输出交换后的数列,每组输出占一行。

运行代码

#include <iostream>
#include <vector>
using namespace std;
int main() {
    int n;
    vector<int> nums;
    while (cin >> n && n != 0) {
        nums.resize(n); 
        for (int i = 0; i < n; ++i) {
            cin >> nums[i];
        }
        int min = 0;
        for (int j = 1; j < n; ++j) {
            if (nums[j] < nums[min]) {
                min = j;
            }
        }
        swap(nums[0], nums[min]);
        for (int num : nums) {
            cout << num << " ";
        }
        cout << endl; 
    }
    return 0;
}

代码思路

  1. 引入头文件和命名空间
  • 引入<iostream>用于输入输出操作。
  • 引入<vector>用于动态数组操作。
  • 使用using namespace std;来避免在后续代码中重复写std::前缀。
  1. 主函数
  • 声明一个整数n用于表示接下来要输入的整数的数量。
  • 声明一个vector<int>类型的nums用于存储整数序列。
  1. 读取和处理序列
  • 使用while循环持续读取输入,直到输入一个0为止(题目中给出的结束条件)。
  • 在每次循环中:读取整数n。使用nums.resize(n);调整nums的大小为n,如果nums之前的大小小于n,则会用默认值(对于int是0)填充新增的元素;如果nums之前的大小大于n,则会删除多余的元素。使用for循环读取n个整数并存储在nums中。
  1. 找到最小元素并移动到开头
  • 初始化一个变量min为0,表示当前假设的最小元素索引。
  • 使用for循环遍历nums中的每个元素(从索引1开始,因为我们已经假设索引0的元素是最小的):如果当前元素nums[j]小于nums[min],则更新minj
  • 使用swap(nums[0], nums[min]);交换索引0和min的元素,从而将最小元素移动到序列的开头。
  1. 输出修改后的序列
  • 使用基于范围的for循环遍历nums并输出每个元素,元素之间用空格分隔。
  • 输出一个换行符,表示一个序列的输出结束。
  1. 结束程序:当输入为0时,while循环结束,程序正常退出。

题目五:2017.字符串统计

题目描述

Problem Description:对于给定的一个字符串,统计其中数字字符出现的次数。

Input:输入数据有多行,第一行是一个整数n,表示测试实例的个数,后面跟着n行,每行包括一个由字母和数字组成的字符串。

Output:对于每个测试实例,输出该串中数值的个数,每个输出占一行。

运行代码

#include <iostream>  
#include <string>  
using namespace std;
int count(const string& str) {
    int count = 0;
    for (char c : str) {
        if (c >= '0' && c <= '9') {
            count++;
        }
    }
    return count;
}
int main() {
    int n;
    cin >> n;
    cin.ignore(); 
    while (n--) {
        string str;
        getline(cin, str); 
        cout << count(str) << endl;
    }
    return 0;
}

代码思路

  1. 定义函数:首先,定义了一个名为countDigits的函数,这个函数的任务是统计传入的字符串中数字字符(即'0'到'9'之间的字符)的数量。
  2. 遍历字符串:在countDigits函数中,使用了一个基于范围的for循环(C++11及以后版本支持)来遍历传入的字符串中的每个字符。这种循环方式非常简洁,它会自动遍历字符串中的每个字符,并将它们赋值给循环变量c
  3. 检查字符:在循环体内,通过检查字符c的ASCII值是否在'0'到'9'之间来确定它是否是一个数字字符。如果是,就增加计数器count的值。
  4. 读取测试实例数量:在main函数中,首先读取一个整数n,它表示将要处理的测试实例的数量。
  5. 处理换行符:由于读取n之后输入流中可能还包含一个换行符,所以使用cin.ignore()来忽略它。这一步很重要,因为如果不忽略这个换行符,接下来的getline调用可能会立即返回,而不等待用户输入。
  6. 读取和处理每个测试实例:使用一个while循环来重复处理n个测试实例。在每次循环中,使用getline函数读取一整行字符串(包括其中的空格),然后调用countDigits函数来统计字符串中数字字符的数量,并将结果输出到控制台。
  7. 输出结果:对于每个测试实例,输出一行包含数字字符数量的结果。

题目六:2019.数列有序

题目描述

Problem Description:有n(n<=100)个整数,已经按照从小到大顺序排列好,现在另外给一个整数x,请将该数插入到序列中,并使新的序列仍然有序。

Input:输入数据包含多个测试实例,每组数据由两行组成,第一行是n和m,第二行是已经有序的n个数的数列。n和m同时为0标示输入数据的结束,本行不做处理。

Output:对于每个测试实例,输出插入新的元素后的数列。

运行代码

#include <iostream>
#include <vector>
using namespace std;
void Print(int n, int x, const vector<int>& nums) {
    vector<int> result(nums.begin(), nums.end()); 
    result.push_back(x); 
    int i = n - 1;
    while (i >= 0 && result[i] > x) {
        result[i + 1] = result[i];
        --i;
    }
    result[i + 1] = x; 
    for (int num : result) {
        cout << num << " ";
    }
    cout << endl;
}
int main() {
    int n, m;
    while (cin >> n >> m && n != 0 && m != 0) {
        vector<int> nums(n);
        for (int i = 0; i < n; ++i) {
            cin >> nums[i];
        }
        Print(n, m, nums); 
    }
    return 0;
}

代码思路

  1. 包含头文件:
  • 包含<iostream>用于输入输出操作。
  • 包含<vector>以使用向量容器来存储整数序列。
  1. 定义函数Print:
  • 输入参数为序列长度n、待插入的整数x,以及原有序列nums的引用。
  • 首先,通过拷贝构造函数创建原序列的副本result,并在其后添加待插入的数x
  • 初始化索引i为序列长度减1,用于从序列尾部向前查找插入位置。
  • 使用while循环比较并移动大于x的元素,为x腾出位置。循环条件是i >= 0且当前元素大于x
  • 找到插入位置后,将x放入result[i + 1]
  • 遍历并打印结果序列result,每个元素后跟一个空格,最后换行。
  1. main函数逻辑:
  • 定义变量nm,分别用于存储序列长度和待插入的整数。
  • 使用while循环持续读取输入,直到遇到n = 0m = 0为止,这标志着输入结束。
  • 在每次循环中,读取原有序列的每个元素并存储在向量nums中。
  • 调用Print函数,传入序列长度、待插入整数和原序列,完成插入并打印操作。

综上所述,这段代码的核心思想是实现一个简单的插入排序算法的一部分——即在已排序列表中找到特定元素的正确位置并插入,而不是对整个无序列表进行排序。它通过逐步比较并移动元素来高效地定位插入点,从而维持了序列的有序状态。

目录
相关文章
|
7月前
|
算法 开发工具 计算机视觉
【零代码研发】OpenCV实验大师工作流引擎C++ SDK演示
【零代码研发】OpenCV实验大师工作流引擎C++ SDK演示
103 1
|
7月前
|
存储 JavaScript 前端开发
程序与技术分享:C++程序设计实验考试准备资料(2019级秋学期)
程序与技术分享:C++程序设计实验考试准备资料(2019级秋学期)
|
7月前
|
存储 人工智能 测试技术
C++课程设计实验杭州电子科技大学ACM题目(下)
C++课程设计实验杭州电子科技大学ACM题目(下)
47 0
|
7月前
|
存储 C++
C++课程设计实验杭州电子科技大学ACM题目(上)
C++课程设计实验杭州电子科技大学ACM题目(上)
41 0
|
4天前
|
C++ 芯片
【C++面向对象——类与对象】Computer类(头歌实践教学平台习题)【合集】
声明一个简单的Computer类,含有数据成员芯片(cpu)、内存(ram)、光驱(cdrom)等等,以及两个公有成员函数run、stop。只能在类的内部访问。这是一种数据隐藏的机制,用于保护类的数据不被外部随意修改。根据提示,在右侧编辑器补充代码,平台会对你编写的代码进行测试。成员可以在派生类(继承该类的子类)中访问。成员,在类的外部不能直接访问。可以在类的外部直接访问。为了完成本关任务,你需要掌握。
36 18
|
4天前
|
存储 编译器 数据安全/隐私保护
【C++面向对象——类与对象】CPU类(头歌实践教学平台习题)【合集】
声明一个CPU类,包含等级(rank)、频率(frequency)、电压(voltage)等属性,以及两个公有成员函数run、stop。根据提示,在右侧编辑器补充代码,平台会对你编写的代码进行测试。​ 相关知识 类的声明和使用。 类的声明和对象的声明。 构造函数和析构函数的执行。 一、类的声明和使用 1.类的声明基础 在C++中,类是创建对象的蓝图。类的声明定义了类的成员,包括数据成员(变量)和成员函数(方法)。一个简单的类声明示例如下: classMyClass{ public: int
31 13
|
4天前
|
编译器 数据安全/隐私保护 C++
【C++面向对象——继承与派生】派生类的应用(头歌实践教学平台习题)【合集】
本实验旨在学习类的继承关系、不同继承方式下的访问控制及利用虚基类解决二义性问题。主要内容包括: 1. **类的继承关系基础概念**:介绍继承的定义及声明派生类的语法。 2. **不同继承方式下对基类成员的访问控制**:详细说明`public`、`private`和`protected`继承方式对基类成员的访问权限影响。 3. **利用虚基类解决二义性问题**:解释多继承中可能出现的二义性及其解决方案——虚基类。 实验任务要求从`people`类派生出`student`、`teacher`、`graduate`和`TA`类,添加特定属性并测试这些类的功能。最终通过创建教师和助教实例,验证代码
21 5
|
4天前
|
存储 算法 搜索推荐
【C++面向对象——群体类和群体数据的组织】实现含排序功能的数组类(头歌实践教学平台习题)【合集】
1. **相关排序和查找算法的原理**:介绍直接插入排序、直接选择排序、冒泡排序和顺序查找的基本原理及其实现代码。 2. **C++ 类与成员函数的定义**:讲解如何定义`Array`类,包括类的声明和实现,以及成员函数的定义与调用。 3. **数组作为类的成员变量的处理**:探讨内存管理和正确访问数组元素的方法,确保在类中正确使用动态分配的数组。 4. **函数参数传递与返回值处理**:解释排序和查找函数的参数传递方式及返回值处理,确保函数功能正确实现。 通过掌握这些知识,可以顺利地将排序和查找算法封装到`Array`类中,并进行测试验证。编程要求是在右侧编辑器补充代码以实现三种排序算法
18 5
|
4天前
|
Serverless 编译器 C++
【C++面向对象——类的多态性与虚函数】计算图像面积(头歌实践教学平台习题)【合集】
本任务要求设计一个矩形类、圆形类和图形基类,计算并输出相应图形面积。相关知识点包括纯虚函数和抽象类的使用。 **目录:** - 任务描述 - 相关知识 - 纯虚函数 - 特点 - 使用场景 - 作用 - 注意事项 - 相关概念对比 - 抽象类的使用 - 定义与概念 - 使用场景 - 编程要求 - 测试说明 - 通关代码 - 测试结果 **任务概述:** 1. **图形基类(Shape)**:包含纯虚函数 `void PrintArea()`。 2. **矩形类(Rectangle)**:继承 Shape 类,重写 `Print
19 4
|
4天前
|
设计模式 IDE 编译器
【C++面向对象——类的多态性与虚函数】编写教学游戏:认识动物(头歌实践教学平台习题)【合集】
本项目旨在通过C++编程实现一个教学游戏,帮助小朋友认识动物。程序设计了一个动物园场景,包含Dog、Bird和Frog三种动物。每个动物都有move和shout行为,用于展示其特征。游戏随机挑选10个动物,前5个供学习,后5个用于测试。使用虚函数和多态实现不同动物的行为,确保代码灵活扩展。此外,通过typeid获取对象类型,并利用strstr辅助判断类型。相关头文件如&lt;string&gt;、&lt;cstdlib&gt;等确保程序正常运行。最终,根据小朋友的回答计算得分,提供互动学习体验。 - **任务描述**:编写教学游戏,随机挑选10个动物进行展示与测试。 - **类设计**:基类
17 3