博客
关于我
第7周编程作业
阅读量:526 次
发布时间:2019-03-08

本文共 3760 字,大约阅读时间需要 12 分钟。

首先,我们来详细分析并解决每个编程题目:

1. 函数重置两个变量的值

目标:编写一个函数,重置两个变量的值,使它们变为原值的平均值。思路:计算两个变量的总和,判断是否为偶数。根据情况计算平均值,并进行四舍五入处理,然后将结果保存到两个变量中。实现代码

#include 
using namespace std;void reset(int *a, int *b) { int sum = *a + *b; if (sum % 2 != 0) { *a = *b = (sum + 1) / 2; // 四舍五入,例如7+14=21,21/2=10.5,取11 } else { *a = *b = sum / 2; }}int main() { int x, y; cin >> x >> y; reset(&x, &y); cout << x << " " << y << endl; return 0;}

2. 数组求和函数

目标:编写一个函数,按次调用的方式累加数组元素的值。思路:使用静态变量来累加每次传入的值。实现代码

#include 
using namespace std;void add_array(int a) { static int sum = 0; sum += a; return sum;}int main() { int array[100], x; bool end = false; int count = 0; while (!end) { cin >> x; if (x == -1) { end = true; break; } array[count++] = x; } int total = 0; for (int i = 0; i < count; i++) { add_array(array[i]); } cout << add_array(0) << endl; // 总和通过指针返回 return 0;}

3. 数组清零函数

目标:将数组的前n个元素置零,返回指针。思路:从数组起始位置到指定位置-1的位置,依次赋值为0。实现代码

#include 
using namespace std;void emptyList(int *p, int empty_num) { for (int i = 0; i < empty_num; i++) { p[i] = 0; }}int main() { int array[100], *plist = array; int num; bool end = false; int count = 0; while (!end) { cin >> num; if (num == -1) { end = true; break; } array[count++] = num; } cin >> count; // 读取要清零的数量 emptyList(plist, count); for (int i = =0; i < 100; ++i) { if (i < count) { cout << 0 << " "; } else { if (i != 99) { continue; } cout << array[i] << endl; // 最后一个元素不添加空格 } } return 0;}

4. 函数指针加密处理

目标:编写两个加密函数,并用函数指针进行切换。凯撒加密函数

void caesar(char s[]) {    for (char *p = s; *p != 0; p++) {        if (*p >= 'a' && *p <= 'z') {            *p += 3; // 向后移动三位            if (*p > 'z') {                *p = 'a';            }        } else if (*p >= 'A' && *p <= 'Z') {            *p += 3; // 向后移动三位            if (*p > 'Z') {                *p = 'A';            }        }    }}

单双号加密函数

void oddeven(char s[]) {    int odd_pos = 0, even_pos = 0;    char *p = s;    while (*p != 0) {        if ((p - s) % 2 == 0) {            // 偶数位置            odd_pos++;            p++;        } else {            // 奇数位置            even_pos++;            p++;        }    }    // 交换奇偶位置    char temp;    for (int i = 0; i < min(odd_pos, even_pos); i++) {        temp = s[even_pos];        s[even_pos] = s[odd_pos];        s[odd_pos] = temp;        odd_pos++;        even_pos--;    }}

主函数

#include 
using namespace std;void caesar(char s[]);void oddeven(char s[]);int main() { char ch[40]; int chosen_method; cin >> ch; cin >> chosen_method; void (*fp)(char s[]) = nullptr; if (chosen_method == 1) { fp = caesar; } else if (chosen_method == 2) { fp = oddeven; } if (fp) { fp(ch); cout << ch << endl; } return 0;}

5. 通用函数区间平均值计算

目标:编写通用函数计算任意函数在区间内的平均值。通用函数

#include 
using namespace std;int avg(int (*fp)(int), int x1, int x2) { int sum = 0; int count = x2 - x1 + 1; for (int i = x1; i <= x2; ++i) { sum += fp(i); } int average = sum / count; return average;}

主函数

#include 
using namespace std;int a = 0, b = 0, c = 0, m = 0;int fun1(int x) { return 3*x*x + 2*x + 1; }int fun2(int x) { return pow(x, m); }int main() { cin >> a >> b >> c; cin >> m; cin >> x1 >> x2; int s1 = avg(fun1, x1, x2); int s2 = avg(fun2, x1, x2); cout << s1 << endl << s2 << endl; return 0;}

总结

每个任务都需要细致地分析需求,确保函数逻辑正确,尤其是处理数组、字符串和函数指针的部分,需要注意易引发的错误,如数组越界、静态变量的影响及函数指针的正确赋值和调用。通过逐一解决每个小问题,可以高效完成编程任务。

转载地址:http://dlziz.baihongyu.com/

你可能感兴趣的文章
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>
Mysql 分页语句 Limit原理
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 删除日志文件详解
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>