|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
所谓回文数,就是说一个数字从左边读和从右边读的结果是一模一样的,比如12321。
现在给出n个一位整数数字,请问:从这n个数字中任选一些数字,能拼成的最长回文数 是多少位?
输入:一个整数n(1<=n<=100,表示随后将输入的数字个数)。
然后输入n个一位非负整数数字,即其取值范围为[0, 9]。
输出:能拼成的最长回文数的位数。
#include <stdio.h>
int main() {
int n;
int i,s=0;
scanf("%d",&n);
int a[10000],b[10000];
for(i=0; i<n; i++) {
scanf("%d",&a[i]);
}
for(i=0; i<n; i++) {
b[a[i]]++;
}
for(i=0; i<n; i++) {
if(b[i]==1)
b[i]=0;
else if(b[i]%2!=0)
b[i]=b[i]-1;
}
// {
// for(i=0; i<n; i++)
// printf("%d %d\n",b[i],i);
//
// }
for(i=0; i<n; i++)
s+=b[i];
printf("%d",(s==n)?s:s+1);
}
本帖最后由 jackz007 于 2021-11-27 12:37 编辑
- #include <stdio.h>
- int main(void)
- {
- int a[10000] , b[10000] , c , i , n , s = 0 ;
- scanf("%d" , & n) ;
- for(i = 0 ; i < n ; i ++) scanf("%d" , & a[i]) ;
- for(i = 0 ; i < n ; i ++) b[a[i]]++ ;
- for(c = i = s = 0 ; i < n ; i ++) {
- s += (b[a[i]] % 2) ? b[a[i]] - 1 : b[a[i]] ;
- if(b[a[i]] % 2) c ++ ;
- }
- if(c) s ++ ;
- printf("%d\n" , s) ;
- }
复制代码
你代码的最大问题是循环中的 b[ i ] 不可以直接用 i,而必须一律用 a[ i ] 来做索引,像这样 b[a[ i ]]。剩下的就是策略问题,应该在统计过程中对原始数据作取舍,不可以直接修改原始数据。一旦改错了,后面就没有机会纠正了。
|
|