算法设计相关编程题

1.百鸡问题扩展-N鸡问题
问题描述
N元钱买N只鸡,公鸡每只5元,母鸡每只3元,小鸡1元3只,N元钱必须刚好买N只鸡,而且鸡必须整只买,不能劈开买。
有几种买法呢?这就是N鸡问题。

输入在一行中输入一个正整数N。(N<500)
输出在一行中输出两个整数c s,中间用一个空格隔开,表示N元钱买N只鸡共有 c 种买法,且所有买法的公鸡数量之和是 s。如果无解,则 s 为 -1.

输入样例1:
100
输出样例1:
4 24

import java.util.Scanner;

public class Main {
   
	public static void main(String[] args) {
   
		Scanner in=new Scanner(System.in);
		int n=in.nextInt();
		//定义公鸡,母鸡,小鸡数量
		int x,y,z;
		int w[]=new int[n/5];
		int count=0;
		int temp=0;
		for(x=0;x<=n/5;x++) {
   
			for(y=0;y<=n/3;y++) {
   
				z=n-x-y;
				if((z%3==0)&&(5*x+3*y+z/3==n)) {
   
					//System.out.println("公鸡数量"+x+",母鸡数量"+y+",小鸡数量"+z);
					temp+=x;
					count++;	
				}
			}
		}
		if(count==0) {
   
			temp=-1;
			System.out.println(count+" "+temp);
		}else {
   
			System.out.println(count+" "+temp);
		}
    }
}

2.统计数字问题
问题描述
一本书的页码从自然数1 开始顺序编码直到自然数n。书的页码按照通常的习惯编排,每个页码都不含多余的前导数字0。数字计数问题要求对给定书的总页码n(<=200000),计算出书的全部页码中分别用到多少次数字0,1,2,…,9。

输入只有1行,给出表示书的总页码整数n。
输出共有10行,在第k行输出页码中用到的数字k-1的次数,k=1,2,3,…,10
输入样例:
输入示例。例如:
11
输出样例:
输出示例。例如:
1
4
1
1
1
1
1
1
1
1

代码如下:

import java.util.*;

public class Main {
   
    public static void main(String[] args) {
   
        Scanner cin = new Scanner(System.in);
        int a[] = new int[15],x;
        int n,i;
        n = cin.nextInt();
        for(i=1;i<=n;i++)
        {
   
            x = i;
            while(x!=0)
            {
   
                a[x%10]++;
                x /= 10;
            }
        }
        for(i=0;i<=9;i++)
            System.out.println(a[i]);
        cin.close();
    }
}

3.计算斐波那契数列第n项的值
问题描述:
斐波那契数列(Fibonacci Sequence),又称黄金分割数列,指的是这样一个数列:1、1、2、3、5、8、13、21、……。在数学上,斐波纳契数列以递推的方法定义为:F(1)=1,F(2)=1,F(n)=F(n-1)+F(n-2)(n≥2,n∈N)。计算斐波那契数列第n项的值。

输入格式:
输入一个大于等于1࿰

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值