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;
}