周末作业-循环练习题(1)

  1. 判断101-200之间有多少个素数,并输出所有素数。

    count = 0
    for i in range(101 , 201):
        for j in range(2 , int(i ** 0.5)+1):
            if i % j == 0:
                break
        else:
            count += 1
            print(i)
    
  2. 求整数1~100的累加值,但要求跳过所有个位为3的数。

    total = 0
    for i in range(1 , 101):
        if i % 10 != 3:
            total += i
    print(total)
    
  3. 有⼀分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的第20个分数

  4. 写程序计算 n 的阶乘 n! 的结果

    N = int(input('N = :'))
    num = 1
    for i in range(1 , N+1):
        num *= i
    print(num)
    
  5. 求1+2!+3!+…+20!的和

    sum = 0
    for i in range(1 , 21):
        num = 1
        for j in range(1 ,i+1):
            num *= j
        su += num
    print(sum)
    
  6. 写程序求表达式 a + aa + aaa + aaaa+ … 的结果,其中a是1~9的数字,求和的项数用n来控制。(a和n可以用变量来表示)

    a = input('a =:')
    n = int(input('n =:'))
    total = 0
    for i in range(1 , n+1):
        total += int(a*i)
    print(total)
    

    例如:a为3, n为5的时候: 3 + 33 + 333 + 3333 + 33333

  7. 控制台输出三角形

    a.根据n的值的不同,输出相应的形状
    n = 5时             n = 4
    *****               ****
    ****                ***
    ***                 **
    **                  *
    *
    
    n = int(input('n = :'))
    for i in range(n , 0 , -1):
        print('*'* i)
    
    
    
    
    b.根据n的值的不同,输出相应的形状(n为奇数)
    n = 5               n = 7
      *                    *
     ***                  ***
    *****                *****
                        *******
    
    
    n = int(input('n = :'))
    for i in range(1 , n+1):
        a = n - i
        print(' ' * a, '* ' * i, ' ' * a )
    
    
    c. 根据n的值的不同,输出相应的形状
    n = 4
       1
      121
     12321
    1234321
    
    n = 5
        1
       121
      12321
     1234321
    123454321
    
  8. 小明单位发了100元的购物卡,小明到超市买三类洗化用品,洗发水(15元),香皂(2元),牙刷(5元)。要把100元正好花掉,可有哪些购买结合?

    for i in range(0 , 6):
        for j in range(0 , 20):
            for x in range(0 , 50):
                if i * 15 + j * 5 + x * 2 == 100:
                    print(i , j , x)
    
  9. 一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?

num = 0.08
count = 0
while True:
    num *= 2
    count +=1
    if num >= 8848.13*1000:
        print(count)
        break
  1. 古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

    a = 1
    b = c = d = e = 0
    sun = 0
    n = int(input('n = :'))
    for i in range(1, n+1):
        a, b, c, d = d, a, b, d+c
    print(a*2 + b*2 + c*2+d*2)
    
  2. 将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。

  3. 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值

    a = b = c = d = 0
    num = int(input('请输入一个数:'))
    a = num // 1000
    b = num // 100 % 10
    c = num // 10 % 10
    d = num % 10
    a = (a +5) % 10
    b = (b +5) % 10
    c = (c +5) % 10
    d = (d +5) % 10
    a,b,c,d = d,c,b,a
    print(a*1000+b*100+c*10+d)
    
  4. 本金10000元存入银行,年利率是千分之三。每过1年,将本金和利息相加作为新的本金。计算5年后,获得的本金是多少。

    sun = 10000
    for i in range(1, 6):
        interest = (sun / 1000) * 3
        sun += interest
    print(sun)
    
  5. 输入一个整数,计算它各位上数字的和。(注意:输入的整数可以是任意位)

    sun = 0
    num = int(input('请输入一个整数:'))
    while True:
        a = num % 10
        sun +=a
        num //= 10
        if num // 10 ==0:
            sun += num
            break
    print(sun)
    
  6. 求两个数的最大公约数和最小公倍数。(提示:公约数一定小于等于两数中的小的那个数,且能同时被两个数整除;公倍数一定大于等于两数中的大数,且是大数的倍数又能被两数中的小数整除)

    print('请输入两个数')
    a = int(input('a = :'))
    b = int(input('b = :'))
    if a < b:
        for i in range(a , 0 , -1):
            if b % i ==0 and a % i ==0:
                print(f'{a}{b}的最大公约数为{i}')
                break
        b1 = b
        while True:
            if b1 % b == 0 and b1 % a == 0:
                print(f'{a}{b}的最小公倍数是{b1}')
                break
            else:
                b1 += b
    elif a>b:
        for i in range(b , 0 , -1):
            if b % i ==0 and a % i ==0:
                print(f'{a}{b}的最大公约数为{i}')
                break
        a1 = a
        while True:
            if a1 % b == 0 and a1 % a == 0:
                print(f'{a}{b}的最小公倍数是{a1}')
                break
            else:
                a1 += a
    else:
        print(f'{a}{b}的最大公约数为{a}')
        print(f'{a}{b}的最小公倍数是{a}')
        
        
    
在Spring Boot应用中,如果你想要允许跨域请求并在周末(周六、周日)特定时间开启Access-Control-Allow-Origin策略,你可以创建一个自定义过滤器(Filter),例如使用`@CrossOrigin`注解,并通过`@PreAuthorize`或`@ConditionalOnDate`来控制其生效的时间。 首先,创建一个定制的过滤器,比如`WeekendCorsFilter.java`: ```java import org.springframework.boot.actuate.autoconfigure.web.server.ManagementServerProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.http.HttpHeaders; import org.springframework.stereotype.Component; import org.springframework.util.StringUtils; @Configuration @Component public class WeekendCorsFilter { private final ManagementServerProperties management; public WeekendCorsFilter(ManagementServerProperties management) { this.management = management; } @Bean(name = "weekendCorsFilter") public WebMvcConfigurer corsConfigurer() { return (configurer) -> { configurer.addCorsConfiguration( "/**", // 允许所有的路径 headers -> { if (isWeekend()) { // 检查是否为周末 headers.setAllowCredentials(true); // 设置允许凭证 headers.addAllowedHeader("*"); // 允许所有头信息 headers.addAllowedMethod("*"); // 允许所有HTTP方法 headers.addAllowedOrigin("*"); // 允许来自任何源的请求 } else { // 非周末则按默认设置或你自己的规则处理 configurer.cors().allowCredentials(false); configurer.cors().allowedOrigins("http://your-origin.com"); } }); }; } private boolean isWeekend() { String[] daysOfWeek = {"Saturday", "Sunday"}; for (String day : daysOfWeek) { if (management.getEndpointProperties().getWeb().getDatepatterns().contains(day)) { return true; // 如果找到对应的日期模式,则为周末 } } return false; } } ``` 然后在启动类或Spring Boot Actuator配置中启用这个过滤器: ```java @SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } @Autowired private WeekendCorsFilter weekendCorsFilter; // ... @PostConstruct public void init() { weekendCorsFilter.corsConfigurer(); // 加载配置 } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值