| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2555 人关注过本帖
标题:最长不下降子序列
只看楼主 加入收藏
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
结帖率:79.37%
收藏
已结贴  问题点数:50 回复次数:15 
最长不下降子序列
题目在:http://www.
我的程序:
程序代码:
#include <stdio.h>
#include <stdlib.h>
int longest_increasing(int num[],int n)
{

 int lis[100000],j,maxn=0,i;

 for(i=0;i<n;i++)

 {
  if(num[i]==0)continue;
  lis[i]=1;
  for(j=0;j<i;j++)
  if(num[i]>num[j]&&lis[j]+1>lis[i])
   lis[i]=lis[j]+1;

 }

 for(i=0;i<n;i++)

 if(maxn<lis[i])
  maxn=lis[i];

 return maxn;
}
int main()
{

 int num[100000]={0},n,i,max;

 scanf('%d',&n);//输入数据数量
 for(i=0;i<n;i++)

 scanf('%d',&num[i]);

 max=longest_increasing(num,n);//求出连续子段和
 printf('%d',max);//打印最大值
 system('pause');

 return 0;
}
只得了40分,大家看看我这个错在那里了?
搜索更多相关主题的帖子: 序列 
2010-12-14 17:49
我不是傐守
Rank: 1
等 级:禁止发言
帖 子:4
专家分:0
注 册:2010-12-12
收藏
得分:0 
提示: 作者被禁止或删除 内容自动屏蔽
2010-12-14 17:57
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
有nlogn的算法,但是我想明白为什么我这个题解会错

欢迎来到我的博客:http://blog..cn/noisunyuhong
2010-12-14 18:02
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
程序代码:
#include <stdio.h>
#include <stdlib.h>
int longest_increasing(int num[],int n)
{
int lis[100000],j,maxn=0,i;
for(i=0;i<n;i++)
{
  if(num[i]==0)continue;
  lis[i]=1;
  for(j=0;j<i;j++)
  if(num[i]>num[j]&&lis[j]+1>lis[i])
   lis[i]=lis[j]+1;
}
for(i=0;i<n;i++)
if(maxn<lis[i])
  maxn=lis[i];
return maxn;
}
int main()
{
int num[100000]={0},n=0,i,max;
scanf("%d",&n);//输入数据数量
for(i=0;i<n;i++)
scanf("%d",&num[i]);
max=longest_increasing(num,n);//求出连续子段和
if(max==0)
printf("1");
else
printf("%d",max);//打印最大值
system("pause");
return 0;
}

欢迎来到我的博客:http://blog..cn/noisunyuhong
2010-12-14 19:39
yu_hua
Rank: 2
等 级:论坛游民
帖 子:222
专家分:95
注 册:2006-8-10
收藏
得分:20 
//我也来凑个热闹!
#include<stdio.h>
int data[ ][3]={8,0,-1, 3,0,-1, 18,0,-1, 7,0,-1, 14,0,-1, 10,0,-1, 12,0,-1, 23,0,-1, 41,0,-1, 16,0,-1, 24,1,-1};
int Nterm;
int maxlen(int k)
{
    int i,dat=data[k][0],lmax;
    for(i=k+1;i<Nterm;i++)
    {
        if(data[i][0]>=dat)
           lmax=1+data[i][1];
        if(lmax>data[k][1])
        {
           data[k][1]=lmax;
           data[k][2]= i;
        }
    }
    return data[k][1];
}

int main( void )
{
    int ii,lenmax,head;
    Nterm=sizeof(data)/sizeof(data[0][0])/3;
    for(ii=Nterm-2;ii>=0;ii--)
    {
        maxlen(ii);
    }
    lenmax=0;
    for(ii=0;ii<Nterm;ii++)
     if(lenmax<data[ii][1])
     {
        lenmax=data[ii][1];
        head=ii;
     }
    printf("最长不降子序列有%d个元素: \n",lenmax);
    do
    {
        printf("%d\t",data[head][0]);
        head = data[head][2];
    }
    while(head>=0);
    printf("\n\n");
    return 0;
}
2010-12-15 05:22
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
笑,这个程序干脆就0分了

欢迎来到我的博客:http://blog..cn/noisunyuhong
2010-12-15 19:59
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
这个程序为什么不管怎么输出都是13

欢迎来到我的博客:http://blog..cn/noisunyuhong
2010-12-15 19:59
逐渐学习
Rank: 6Rank: 6
等 级:侠之大者
帖 子:113
专家分:454
注 册:2010-9-26
收藏
得分:30 
为了增加顾客,Sally的店铺决定提供免费午餐,顿时门庭若市,但是不久Sally的原材料不足了….因此Sally决定公布一项决定:凡是来本店吃免费午餐的,一天吃能吃一次,吃的数量必须比上一次吃的少, 点的必须在上一次后面,且免费午餐将只有N个种类任君选择,为了能吃到最多的免费午餐,你将如何安排每日吃的数量呢?

样例输入
5
5 4 3 2 1
样例输出
5
楼主把判定条件if(num[i]>num[j]&&lis[j]+1>lis[i])改为
if(num[i]<num[j]&&lis[j]+1>lis[i])就能按题意实现了
题意是(吃的数量必须比上一次吃的少)

帮人《---》帮己
2010-12-16 15:59
a343637412
Rank: 7Rank: 7Rank: 7
来 自:そ ら
等 级:黑侠
帖 子:357
专家分:620
注 册:2010-9-26
收藏
得分:0 
#include <stdio.h>
#include <stdlib.h>
int longest_increasing(int num[],int n)
{
    int lis[100000],j,maxn=0,i;
    for(i=0;i<n;i++)
    {
        if(num[i]==0)continue;
        lis[i]=1;
        for(j=0;j<i;j++)
            if(num[i]>num[j]&&lis[j]+1>lis[i])
                lis[i]=lis[j]+1;
    }
    for(i=0;i<n;i++)
        if(maxn<lis[i])
            maxn=lis[i];
        return maxn;
}
int main()
{
    int num[100000]={0},n,i,max;
    scanf("%d",&n);//输入数据数量
    for(i=0;i<n;i++)
        scanf("%d",&num[i]);
    max=longest_increasing(num,n);//求出连续子段和
    printf("%d",max);//打印最大值
    system("pause");
    return 0;
}
2010-12-16 17:05
a343637412
Rank: 7Rank: 7Rank: 7
来 自:そ ら
等 级:黑侠
帖 子:357
专家分:620
注 册:2010-9-26
收藏
得分:0 
咕~~(╯﹏╰)b  


版主已经改好我找到的错了....
2010-12-16 17:06
快速回复:最长不下降子序列
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.020806 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved