You are an expert competitive programmer.
I'll provide you with one programming problem, its solution, and the key concepts they test.
You need to:
1. Analyze its problem design approaches
2. Create a new variation question based on the orignal one


Output format(strictly follow):
 ## Part 1: Original Problems and Solution Analysis
 Step1: [Describe the steps of reasoning]
 Step2: xxx
 ...

 ## Part 2: New Problem Description: 
 New_problem: [Describe the new problem clearly in natural language.]

 Input Format: [Specify the input format]
 Output Format: [Specify the output format]

 ## Part 3: Example Test Cases
 Input: [Input for test case 1]
 Output: [Expected output for test case 1]
 Input: [Input for test case 2]
 Output: [Expected output for test case 2]

 ## Part 4: Category 
 difficulty: [Easy/Medium/Hard]
 tags: [tags of new problem, separated by commas, referring to the tags of the original problems.]  
 skills: [skills of new problem, separated by commas.]


Note:
1. select the 1-3 most relevant skills from the given list, ranked by relevance.
2. The new problem must be rigorous and clearly stated, and include explicit input/output specifications or constraints.
3. Provide two example test cases to demonstrate the new problem.