简单算法——奇因数代数和

        算法才是程序的灵魂,(水平很差,慢慢学习中)以后每次算法实验课的小任务都在这里整理一下吧。都是些非常基础的。适合入门练手。

今天算法课,老师要求实现一个简单的算法。题目描述如下:

定义正整数m的奇因数f(m):

(1) 若m为奇数时,f(m) = m;

(2)若m为偶数时,f(m)为m去除其所有偶因数后的奇因数。例如,f(6) = 3, f(8) = 1 ;

试求奇因数代数和:f(1)-f(2)+f(3)-f(4)+f(5)............f(n);

解:本题的关键在于控制累加时的符号,奇数加,偶数减。求m的奇因数。

/*
author : Bingocoder
2018 : 4 : 26
*/
#include<iostream>
using namespace std;
int main()
{
	int devide(int i);
	int n = 100;
	int count = 0;
	int i = 1;
	int result = 0;
	do 
	{
			
			if (i % 2 == 1)//奇数直接相加
			{
				result += i;
				i++;
			}
			else//判断出偶数,累加时用负号
			{
				result -= devide(i);
				i++;
			}
			count++;
	} while (count < n);
	cout << result << endl;
	system("pause");
	return 0;
}

int devide(int i)
/*实现f(m)求出偶数I的奇因数*/
{
	while (i % 2 == 0)
	{
		i = i / 2;
	}
	return i;
}

测试数据 n = 100时输出1656,  n = 101........后者比前者大101吧大笑大笑

测试环境visual studio 2017 (这个窗口风格是我用过的IDE里面最舒服的!)



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值