博客
关于我
第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 /*! 50100 ... */ 条件编译
查看>>
mysql 1045解决方法
查看>>
mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
查看>>
mui折叠面板点击事件跳转
查看>>
MySQL 8 公用表表达式(CTE)—— WITH关键字深入用法
查看>>
mysql 8 远程方位_mysql 8 远程连接注意事项
查看>>
MUI框架里的ajax的三种方法
查看>>
MySQL 8.0 恢复孤立文件每表ibd文件
查看>>
Mysql 8.0 新特性
查看>>
MultCloud – 支持数据互传的网盘管理
查看>>
MySQL 8.0.23中复制架构从节点自动故障转移
查看>>
MySQL 8.0开始Group by不再排序
查看>>
mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
查看>>
multi swiper bug solution
查看>>
MySQL Binlog 日志监听与 Spring 集成实战
查看>>
MySQL binlog三种模式
查看>>