c#输入三个数选出最大的_【Java编程基本功】(十一)求最大红玫瑰数,求最后剩下的人,根据输入的数选取函数求值...

博客探讨了三个编程题目:当n个人按顺序报数时,最后留下的原始编号;编写函数计算偶数n的1/2+1/4+...+1/n序列和,以及奇数n的1/1+1/3+...+1/n序列和;寻找1到700间最大的红玫瑰数,即所有因子之和等于其两倍的数。通过C#和Java实现代码并展示运行结果。
摘要由CSDN通过智能技术生成

2cdd6b0397bdd3558fab4d69550f0b1c.png

第三十四题

有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。

代码:

<pre style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; background: none;">

public class lianxi34{
 public static void main(String[] args) {
   Scanner in = new Scanner(System.in);
   System.out.println("请输入人数n的值");
   int n = in.nextInt();
   boolean[] a = new boolean[n];
   for(int i=0;i<a.length;i++){
     a[i]=true;
   }

   int left=n,count=0,index=0;
   while(left>1){
     if (a[index]==true) {
       count++;
       if (count==3) {
         count=0;
         a[index]=false;
         left--;
       }
     }
     index++;
     if (index==n) {
       index=0;
     }
   }
   for(int i=0;i<a.length;i++){
     if (a[i]==true) {
       System.out.println("留下的是原来的"+(i+1)+"位");
     }
   }
 }
}

运行结果:

88fa92c09e593d3f7f6cb12d2578dddf.png

第三十五题

编写一个函数,输入n为偶数时,调用函数求1/2+1/4+...+1/n,当输入n为奇数时,调用函数1/1+1/3+...+1/n

代码:

<pre style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; background: none;">

public class lianxi35 {
 public static void main(String[] args) {
   Scanner in = new Scanner(System.in);
   System.out.println("请输入一个正整数:");
   int n = in.nextInt();
   double sum=0;
   if (n%2==0) {
     for(int i=2;i<=n;i+=2){
       sum = sum + (double)1/i;
     }
   }else{
     for(int i=1;i<=n;i+=2){
       sum = sum + (double)1/i;
     }
   }
   System.out.println(sum);
 }
}

运行结果:

ad56001b36b53aee515a8f90fb88ce6c.png

6c79882bfcf92975dd515e15261ce381.png

第三十六题

若正整数N的所有因子之和等于N的倍数,则称N为红玫瑰数(完备数)。如28的所有因子之和为1+2+4+7+14+28=28*2,故28是红玫瑰数。求[1,700]之间最大的红玫瑰数。

代码:

<pre style="margin: 0px; padding: 0px; max-width: 100%; box-sizing: border-box !important; word-wrap: break-word !important; background: none;">

public class lianxi36{
 public static void main(String[] args) {
   for(int n=700;n>=1;n--){
     int sum=0;
     for(int i=1;i<n;i++){
       if(n%i==0){
         sum+=i;
       }
     }
     if(sum%n==0){
       System.out.println(n);
       break;
     }
   }
 }
}

运行结果:

825852bd6e2bcad4a810006a9e7ade5d.png
想学习Java的小伙伴注意啦!我整理了一套从最基础的Java入门级学习到Java框架内容,送给每一位想要学习Java的小伙伴,想要获取资料,可以关注微信公众号“速学Java”哦,这里是小白聚集地,欢迎初学和进阶中的小伙伴~

关注微信公众号:速学Java

22c01066d66737848e796ed0910e8efd.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值