华为OD机试C卷(100分)-用连续自然数之和来表达整数、 最多购买宝石数目(c语言)

C卷(100分)-用连续自然数之和来表达整数

题目描述

一个整数可以由连续的自然数之和来表示。
给定一个整数,计算该整数有几种连续自然数之和的表达式,且打印出每种表达式

输入描述

一个目标整数T (1 <=T<= 1000)

输出描述

该整数的所有表达式和表达式的个数。
如果有多种表达式,输出要求为:自然数个数最少的表达式优先输出,每个表达式中按自然数递增的顺序输出,具体的格式参见样例。
在每个测试数据结束时,输出一行”Result:X”,其中X是最终的表达式个数。

用例

输入 9
输出
9=9
9=4+5
9=2+3+4
Result:3

说明
整数 9 有三种表示方法,第1个表达式只有1个自然数,最先输出,
第2个表达式有2个自然数,第2次序输出,
第3个表达式有3个自然数,最后输出。
每个表达式中的自然数都是按递增次序输出的。
数字与符号之间无空格

输入 10
输出
10=10
10=1+2+3+4
Result:2

说明 无

#include <stdio.h>

void printExpression(int start, int end) {
    printf("%d", start);
    for (int i = start + 1; i <= end; i++) {
        printf("+%d", i);
    }
}

void getResult(int t) {
    int count = 0;

    for (int i = t; i >=1; i--) {
        int sum = 0;
        for (int j = i; j <=t; j++) {
            sum += j;
            if (sum == t) {
                count++;
                printf("%d=", t);
                printExpression(i, j);
                printf("\n");
            } else if (sum > t) {
                break;
            }
        }
    }

    printf("Result:%d\n", count);
}

int main() {
    int t;
    scanf("%d", &t);
    getResult(t);
    return 0;
}

滑动窗口

#include <stdio.h>
#include <stdlib.h>

void printExpression(int start, int end,int t) {
      printf("%d=%d", t,start);
    for (int i = start + 1; i <= end; i++) {
        printf("+%d", i);
    }
     printf("\n");
}

int getResult(int t) {
    int count = 0;
    int sum = 0;
       int i=0;
       for(int j=0;j<=t;j++){
          sum+=j;
          while(sum>t){
           sum-=i;
          i++;
          }
          if(sum==t){
          count++;
          printExpression(i,j,t);
          }

       }
     return count;

}

int main() {
    int t;
    scanf("%d", &t);
    printf("Result:%d\n", getResult(t));
    return 0;
}

(C卷,100分)- 最多购买宝石数目

题目描述

橱窗里有一排宝石,不同的宝石对应不同的价格,宝石的价格标记为 gems[i]
0 ≤ i < n
n = gems.length
宝石可同时出售0个或多个,如果同时出售多个,则要求出售的宝石编号连续;
例如客户最大购买宝石个数为m,购买的宝石编号必须为:gems[i],gems[i+1],…,gems[i+m-1]
0 ≤ i < n
m ≤ n
假设你当前拥有总面值为 value 的钱,请问最多能购买到多少个宝石,如无法购买宝石,则返回0。

输入描述

第一行输入n,参数类型为int,取值范围:[0,10^6],表示橱窗中宝石的总数量。
之后 n 行分别表示从第0个到第n-1个宝石的价格,即 gems[0] 到 gems[n-1] 的价格,类型为int,取值范围:(0,1000]。
之后一行输入v,类型为int,取值范围:[0,10^9],表示你拥有的钱。

输出描述

输出int类型的返回值,表示最大可购买的宝石数量。

用例

输入 7
8
4
6
3
1
6
7
10
输出 3
说明
gems = [8,4,6,3,1,6,7], value = 10
最多购买的宝石为gems[2]至gems[4]或者gems[3]至gems[5]

输入 0
1
输出 0
说明 gems = [], value = 1
因为没有宝石,所以返回0
输入 9
6
1
3
1
8
9
3
2
4
15
输出 4
说明 gems = [6, 1, 3, 1, 8, 9, 3, 2, 4], value = 15
最多购买的宝石为gems[0]至gems[3]

输入 9
1
1
1
1
1
1
1
1
1
10
输出 9
说明 gems = [1, 1, 1, 1, 1, 1, 1, 1, 1], value = 10
最多购买的宝石为gems[0]至gems[8],即全部购买

滑动窗口

#include <stdio.h>
#include <stdlib.h>
#include <limits.h>
#include <math.h>
int getResult(int* gems,int n,int v){
     if(n==0) return 0;
     int ans=INT_MIN;
     int sum=0;
     int i=0;
     for(int j=0;j<n;j++){
          sum+=gems[j];
          while(sum>v){
                sum-=gems[i];
                i++;
          }
           ans=fmax(ans,j-i+1);
     }
     return (ans==INT_MIN?0:ans);
}
int main()
{
     int n;
     scanf("%d",&n);
     int gems[100];
     for(int i=0;i<n;i++){
          scanf("%d",&gems[i]);
     }
     int v;
     scanf("%d",&v);
    printf("%d",getResult(gems,n,v));
    return 0;
}
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我不会起名字呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值