void 数字特征值(int 数字 = 342315)
{//缘由https://ask.csdn.net/questions/1098022
int wei = 1, cai = 数字 - 数字 / 10 * 10, erjz[7] = { 4 }, shijz[7] = {1, 2, 4, 8, 16, 32, 64}, jg = 0;
while (数字)
erjz[7 - wei] = wei % 2 == cai % 2 ? 1 : 0, erjz[7 - wei] ? jg += shijz[wei - 1] : 0, 数字 /= 10, ++wei, cai = 数字 - 数字 / 10 * 10;
cout << jg << endl;
}
void 数字特征值(int 数字 = 342315)
{//缘由https://ask.csdn.net/questions/1098022
int wei = 1, cai = 数字 - 数字 / 10 * 10, shijz = 1, jg = 0;
while (数字)
wei % 2 == cai % 2 ? jg += shijz : 0, 数字 /= 10, ++wei, cai = 数字 - 数字 / 10 * 10, shijz *= 2, cout << jg << "-" <<shijz/2 << endl;
cout << jg << endl;
}
void 数字特征值(int 数字 = 342315)
{//缘由https://ask.csdn.net/questions/1098022
int wei = 1, shijz = 1, jg = 0, he = 0;
while (数字)//三种写法效率测试循环9999999得到的结果是运算符越少时间就越短。
//(he = wei + (数字 - 数字 / 10 * 10)) - he / 2 * 2 ? 0 : jg += shijz, 数字 /= 10, ++wei, shijz *= 2;
(wei++ + (数字 % 10)) % 2 ? 0 : jg += shijz, 数字 /= 10, shijz *= 2;
//(wei++ + (数字 - 数字 / 10 * 10)) % 2 ? 0 : jg += shijz, 数字 /= 10, shijz *= 2;
//wei % 2 == (数字 - 数字 / 10 * 10) % 2 ? jg += shijz : 0, 数字 /= 10, ++wei, shijz *= 2;
//cout << jg << ends;//测试时关闭所有输出观察运行时间作对比
}
clock_t 开始 = clock();
int a = 0; while (++a<9999999)数字特征值(a);
clock_t 结束 = clock(); std::cout << endl;
if ((double)(结束 - 开始) / CLOCKS_PER_SEC*1000000 < 最小时间)最小时间 = (double)(结束 - 开始) / CLOCKS_PER_SEC*1000000;
printf_s("耗时秒s:%lf 耗时微秒us:%lf\n", 最小时间/1000000, 最小时间);