取a与b的最大值

部署运行你感兴趣的模型镜像

题目:There are two int variables : a and b , don't use " if " , " ?: " , " switch " or other judgement statements , find out the biggest one of the two numbers.(有两个变量a和b,不用 " if " , " ?: " , " switch "或其他判断语句,找出两个数中的较大值)程序员面试宝典第三版P40

方案一:

 

int max = ((a+b)+abs(a-b))/2;


方案二:

#include <iostream>
using namespace std;

int greater(int a ,int b);
int main()
{
	int a = 11;
	int b = 32;
	cout << greater(a,b) << endl;
	return 0;
}
int greater(int a ,int b)
{
	int flag;
	flag = (a-b) >> (sizeof(int) * 8 -1); //得到符号位即最高位 0 或 1;
	return -flag * b + (1 + flag) *a ;
}


 


 

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

在WPS表格中,针对A列中存在的重复项,获对应B列中的最大值,可以通过以下几种方法实现: 1. 使用 `MAXIFS` 函数 如果 WPS 表格版本支持 `MAXIFS` 函数,可以直接使用该函数来实现。公式如下: ```excel =MAXIFS(B:B, A:A, A2) ``` 该公式表示在 A 列中查找当前行 A 值相同的项,并返回对应的 B 列中的最大值。 2. 使用数组公式结合 `IF` `MAX` 函数 如果不支持 `MAXIFS` 函数,可以使用数组公式来实现。输入以下公式后按 `Ctrl+Shift+Enter` 组合键确认: ```excel =MAX(IF(A:A=A2, B:B)) ``` 这个公式会根据 A 列的重复项筛选出对应的 B 列数据,并返回其中的最大值。 3. 使用数据透视表 将 A 列 B 列的数据插入到数据透视表中,在“行”区域添加 A 列,在“值”区域添加 B 列,并将值字段设置为“最大值”。这样即可快速汇总每个 A 值对应的最大 B 值。 4. 使用 VBA 宏代码(可选) 如果需要自动化处理,可以使用 VBA 脚本。以下是示例代码: ```vba Sub FindMaxBasedOnDuplicate() Dim ws As Worksheet Set ws = ThisWorkbook.Sheets("Sheet1") '修改为你的工作表名称 Dim dict As Object Set dict = CreateObject("Scripting.Dictionary") Dim i As Long For i = 2 To ws.Cells(ws.Rows.Count, "A").End(xlUp).Row Dim key As Variant key = ws.Cells(i, 1).Value Dim value As Double value = ws.Cells(i, 2).Value If Not dict.Exists(key) Then dict.Add key, value Else If value > dict(key) Then dict(key) = value End If End If Next i '输出结果 Dim outputRow As Long outputRow = 2 For Each key In dict.Keys ws.Cells(outputRow, 3).Value = key 'C列为A列去重后的值 ws.Cells(outputRow, 4).Value = dict(key) 'D列为对应的最大值 outputRow = outputRow + 1 Next key End Sub ``` 此代码会遍历 A 列 B 列的数据,找到每个 A 值对应的最大 B 值,并输出到 C、D 列中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值