ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

2021-08-04 暑假编程练习记录(一)

2021-08-04 17:33:05  阅读:152  来源: 互联网

标签:循环体 04 int 08 long -- while 2021 mod


1.求(n mod 1) or (n mod 2) or ... or (n mod (n - 1)) or (n mod n)

  题意:给定一个整数n,求(n mod 1) or (n mod 2) or ... or (n mod (n - 1)) or (n mod n).

or 代表逻辑或,C++表示为|

输入格式:
每行一个正整数T(1<= T <= 5000),代表测试数据的个数 接下来T行,每行一个数字n(1 <= n <= 1e12)

输出格式:
请你输出对于每个给定的正整数n,带入上式后答案是多少?

输入样例:
2
6
9
输出样例:

3
7

  思路:
1 a mod b意为a除以b之后所得的余数

2 本题通过列举后发现,最终结果均为2的n次方-1这种形式。

3 尝试将n与最终结果联系起来。

  代码:

#include<iostream>
#include<math.h>
using namespace std;
int main(){
    int T;int count;
    long long r;
    cin>>T;
    long long n;//由n的范围决定是long long
    for(int m=0;m<T;m++){
    cin>>n;    
    if(n==1||n==2){
        cout<<"0"<<endl;
        continue;
    }
    else{
    n--;count=0;r=1;
    while(n-1!=0){
        n=n/2;
        count++;//计算是2的几次方
    } 
    for(int j=0;j<count;j++){
        r=r*2;//计算2的n次方
    }
    r--;
    cout<<r<<endl; 
    }
    }
    return 0;
}

      注释:

1 2的n次方的计算方法:

如果n比较小,直接用pow()函数

如果n比较大,可以用快速幂算法/字符串的方法

还可以用(ll)pow() 

(我的代码这种方法很容易出现运行超时的情况)

2 while(n--):先判断n是不是0。如果n不为0,n减1,执行循环体

while(--n):n先减1,再判断n是不是0。如果n不为0,执行循环体。

while(n-1!=0):当n-1存在时执行循环体。


标签:循环体,04,int,08,long,--,while,2021,mod
来源: https://blog.csdn.net/rayray__/article/details/119387641

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有