解题思路:
常规思路,直接写的解嘛。
参考代码:
#include<bits/stdc++.h> #define hh ios::sync_with_stdio(false),cin.tie(0),cout.tie(0); using namespace std; typedef unsigned long long ull; int main() { hh; int n; while(cin>>n){ ull ans=1; while(n>1){ ans=(ans+1)*2; n--; } cout<<ans<<endl; } return 0; }
另一种思路:利用数组。
#include<bits/stdc++.h> #define hh ios::sync_with_stdio(false),cin.tie(0),cout.tie(0); using namespace std; typedef unsigned long long ull; int main(){ hh; ull ans[32]={1},n; for(int i=1;i<=32;i++){ ans[i]=(ans[i-1]+1)*2; } while(cin>>n) cout<<ans[n-1]<<endl; return 0; }
这样更快
0.0分
0 人评分
2005年春浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:490 |
兰顿蚂蚁 (C++代码)浏览:1089 |
C语言程序设计教程(第三版)课后习题6.4 (C语言代码)浏览:597 |
不会做的浏览:870 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:552 |
求组合数 (C语言代码)浏览:1152 |
C语言训练-列出最简真分数序列* (C语言代码)浏览:603 |
C语言程序设计教程(第三版)课后习题7.2 (C语言代码)浏览:797 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:586 |
1014题解浏览:484 |