从N个城市列表中选择一个或多个城市的方法个数
Number of Ways of selecting a city/cities from a list of N cities
有一个从1 to N
开始编号的N个城市的列表。
任务是选择从列表中选择城市的方法个数。
必须选择至少一个城市。由于答案可能很大,因此打印答案模10^9+7
Examples
Input Output
2 (test cases)
2 3
1 1
对于测试用例1:选择城市的唯一方法是1,2,1,2因此答案是3。
对于测试用例2:选择城市的唯一方法是1答案是1.
我尝试了以下方法(C语言):
#include<stdio.h>
#include<math.h>
const long int REM = 1000000000+7;
int main()
{
int t; scanf("%d",&t); while(t--) {
long long int n; scanf("%lld",&n);
long long int res=1;
for(long long int i=0;i<n;i++) {
res<<=1;
res%=(REM);
}
printf("%lldn",res-1);
}
return 0;
}
这是给我的时间限制超出。请给我推荐一个更好的performance algorithm
。
谢谢
答案是2^n - 1
.所有可能子集(除了空集)的个数
由于2^n
将非常大,这就是为什么问题要求做模块化运算,你必须执行模块化幂运算来计算2^n
。
#include<stdio.h>
#include<math.h>
#define MOD 1000000007
// calculate (b^e) % MOD
long long powerMod(long long b, long long e)
{
long long ret = 1;
b %= MOD;
while(e > 0)
{
if(e & 1) {
ret = (ret * b) % MOD;
}
b = (b * b) % MOD;
e >>= 1;
}
return ret % MOD;
}
int main()
{
long long tcase, n;
scanf("%lld",&tcase);
while(tcase--)
{
scanf("%lld", &n);
long long result = powerMod(2, n) - 1;
printf("%lldn", result);
}
return 0;
}
您可以使用二进制指数算法在对数时间内解决每个测试用例
相关文章:
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- 删除一个线程上有数百万个字符串的大型哈希映射会影响另一个线程的性能
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 运行同一解决方案的另一个项目的项目
- 挂起和取消挂起一个文件DLL
- 用C++中的一个变量定义一个常量
- 函数向量_指针有不同的原型,我可以构建一个吗
- 在c++中用vector填充一个简单的动态数组
- 如何在选项卡视图Qt中设置一个新项目,并保存以前的项目
- 预处理器:插入结构名称中的前一个行号
- 我在c++代码中生成了一个运行时#3异常
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 从链接列表c++中删除一个项目
- 告诉一个 const char 数组,除了编译时 C 样式的字符串外,它不以 '