1342[将数字变成0的操作次数]
题目
链接
详情
实例
实例1
实例2
实例3
提示
题解
思路
判断 num 是否为0
不为0则判断 num 是否为偶数
num 是偶数则除以2
num 不是偶数则减1
操作次数加1
重复上述步骤,直到 num 为0,返回操作次数
代码
class Solution {
public:
int numberOfSteps(int num) {
int iCount = 0;
while (num)
{
if (0 == (num % 2))
num /= 2;
else
num -= 1;
iCount++;
}
return iCount;
}
};
1672[最富有客户的资产总量]
题目
链接
详情
实例
实例1
实例2
实例3
提示
题解
思路
先定义一个最大值 iMax 设置为负值,保证资产为0时也可以被存储
再一次遍历每个人的所有资产,求和 iSum
之后比较 iSum 和 iMax 的大小
如果 iSum 大于 iMax 则将 iSum 的值赋给 iMax,即 iMax = iSum,保证 iMax 存储的是最大值
最后输出 iMax
代码
class Solution {
public:
int maximumWealth(vector<vector<int>>& accounts) {
int iMax = -1;
for (int i = 0; i < accounts.size(); i++)
{
int iSum = 0;
for (int j = 0; j < accounts.at(i).size(); j++)
iSum += accounts.at(i).at(j);
if (iMax < iSum)
iMax = iSum;
}
return iMax;
}
};
412[Fizz Buzz]
题目
链接
详情
实例
实例1
实例2
实例3
提示
题解
思路
定义一个容器 sRetVec,依次遍历每一个数
如果可以被3和5同时整除,则在容器内加入一个元素"FizzBuzz",即 1 == ((0 == (num % 3)) && (0 == (num % 5)))
成立,sRetVec.push_back("FizzBuzz")
继续遍历下一个数
如果可以被3整除,则在容器内加入一个元素"Fizz",即 0 == (num % 3)
成立,sRetVec.push_back("Fizz")
继续遍历下一个数
如果可以被3整除,则在容器内加入一个元素"Buzz",即 0 == (num % 5)
成立,sRetVec.push_back("Buzz")
继续遍历下一个数
如果均不行,则将数值转换为字符串并加入容器,即sprintf(buff, "%d", num)//char buff[10] = { 0 };
sRetVec.push_back(buff)
继续遍历下一个数
最后遍历完输出容器
代码
class Solution {
public:
vector<string> fizzBuzz(int n) {
vector<string> sRetVec;
for (int i = 1; i < n + 1; i++)
{
if ((0 == (i % 3)) && (0 == (i % 5)))
sRetVec.push_back("FizzBuzz");
else if (0 == (i % 3))
sRetVec.push_back("Fizz");
else if (0 == (i % 5))
sRetVec.push_back("Buzz");
else
{
char buff[10] = { 0 };
sprintf(buff, "%d", i);
sRetVec.push_back(buff);
}
}
return sRetVec;
}
};
标签:新手村,实例,int,1342,iSum,力扣,num,iMax,sRetVec From: https://www.cnblogs.com/EricsT/p/18527682