Q:找最大数序列
总时间限制: 1000ms 内存限制: 65536kB
描述
输入 n 行,每行不超过 100 个无符号整数,无符号数不超过 4 位。请输出最大整
数以及最大整数所在的行号(行号从 1 开始)。如果该数据在多个行中出现,则按
从小到大输出相应行号,行号之间以一个逗号分开。
输入
一行输入一个正整数 n(n <= 30)。
之后的 n 行,每行包含不超过 100 个无符号整数,整数之间以一个逗号分开。
输出
第一行:最大整数;
第二行:最大整数所在的行编号,逗号间隔。
样例输入
6
1,3,5,23,6,8,14
20,22,13,4,16
23,12,17,22
2,6,10,9,3,6
22,21,20,8,10
22,1,23,6,8,19,23
样例输出
23
1,3,6
S:
#include <stdio.h> int main() { int n,i,x; int a[31]; int mark=0; int max=-1; int first=1; char ch; scanf("%d",&n); getchar(); for(i=0;i<n;i++) { scanf("%d%c",&x,&ch); while(ch==',') { if(x>max) { max=x; mark=0; a[mark]=i; } else if(x==max&&i!=a[mark]) { mark++; a[mark]=i; } ch=' '; scanf("%d%c",&x,&ch); } if(x>max) { max=x; mark=0; a[mark]=i; } else if(x==max&&i!=a[mark]) { mark++; a[mark]=i; } } printf("%d\n",max); for(i=0;i<=mark;i++) { if(first) { printf("%d",a[i]+1); first=0; } else { printf(",%d",a[i]+1); } } printf("\n"); return 0; }